草庐IT

java - 处理多平台(dev/integ/valid/prod ...)开发的最佳解决方案是什么?发货流程

coder 2024-03-29 原文

我不是很有经验,但我参与过一些大型 Java EE 项目(使用 maven2),使用非常不同的方法来处理不同平台上的安装/交付。

1) 其中之一是使用快照进行开发,然后发布组件和主要 Web 应用程序的 Maven 版本。因此交付是:

  • war/ear 文件
  • 列表项
  • 属性文件
  • sgdb 文件
  • 其他一些

团队将使用这些文件将新的应用程序版本放到不同的平台上。 我认为这个过程是严格的,并且允许你始终轻松地保持生产中传递的不同配置,但它不是很灵活,这个过程有点繁重,它有时会导致我们做一些肮脏的事情,比如重写一个 war 类修补回归... 这是一个电子商务网站,每月有 1000 万独立访问者,可用性为 99.89%。

2) 我看到的另一个方法是检查每个平台上的源代码,然后在本地存储库中安装快照工件。然后应用程序服务器将使用 .m2 文件夹的这些快照。 没有真正的交付过程,因为要将新版本投入生产,我们只需要更新组件/webapps 的源,进行一些 maven clean install 并重新启动应用程序服务器。 我认为它更灵活,但我看到了一些缺点,这种方法对我来说似乎很危险。 这个网站有一个前台,我不知 Prop 体数字,但比第一个少得多。它还为一家 13 万员工的公司的大多数员工提供一个大型后台办公室。

我想根据网站、它对公众的展示和所需的可用性,我们必须根据需要调整交付策略。

我不是要问哪种解决方案最好,而是想知道您是否见过不同的情况,以及在哪种情况下您会使用哪种策略?

最佳答案

在没有交易网站的情况下,我不得不参与异构环境中各种大型 (Java) 项目的发布管理过程:

  • 在“PC”上开发,在我们的例子中是指 Windows——遗憾的是现在仍然是 Windows Xp——(和单元测试)
  • 在 Linux 上进行持续集成和系统测试(因为它们的设置成本较低)
  • Solaris 上的预生产和生产(例如 Sun Fire)

我看到的常用方法是:

  • 二进制依赖(每个项目使用其他项目生成的二进制文件,而不是它们的源代码)
  • 无需为集成测试重新编译(在 PC 上生成的 jar 直接用于 linux 场)
  • 预生产时完全重新编译(意味着二进制文件存储在 Maven 存储库中),至少要确保一切都使用相同的 JDK 和销售选项重新编译。
  • 在生产系统上没有 VCS(版本控制系统,如 SVN、Perforce、Git、Mercurial 等):一切都从预生产到 rsynch 部署。

因此,发布管理过程要考虑的各种参数是:

  • 当您开发自己的项目时,您是直接依赖其他项目的源代码还是二进制文件?
  • 您将设置值存储在哪里?
    你对它们进行参数化吗?如果是,你什么时候用它们的最终值替换变量(仅在启动时,还是在运行时?)
  • 您会在最终(预生产)系统上重新编译所有内容吗?
  • 您如何访问/复制/部署您的生产系统?
  • 您如何停止/重新启动/修补您的应用程序?

(这不是一个详尽的 list 。
根据应用程序发布的性质,必须解决其他问题)

关于java - 处理多平台(dev/integ/valid/prod ...)开发的最佳解决方案是什么?发货流程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4554218/

有关java - 处理多平台(dev/integ/valid/prod ...)开发的最佳解决方案是什么?发货流程的更多相关文章

  1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  2. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  3. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  4. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  5. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  6. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

  7. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  8. ruby - ruby 中的 TOPLEVEL_BINDING 是什么? - 2

    它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput

  9. ruby - Infinity 和 NaN 的类型是什么? - 2

    我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串

  10. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

随机推荐