草庐IT

java - 热部署 Java EAR 以最小化或消除服务器上应用程序的停机时间?

coder 2024-03-19 原文

我听说这就是 JavaRebel 所做的,但是有没有其他好的方法来部署新版本的 EAR,同时允许用户在以前的版本上保持 Activity 状态?我们使用 JBoss 作为应用服务器...

最佳答案

这不是 JavaRebel 所做的。 JavaRebel(根据描述)热替换内存中的类。在与系统的现有连接的情况下,这是 Not Acceptable ,因为更新的类可能会破坏客户端的逻辑。

曾经我工作的公司也遇到过类似的问题,是这样解决的:

  • 使用智能路由器作为负载均衡器
  • 新版本已部署到(新)集群的 50% 的节点
  • 新连接严格传递给这些更新的节点,旧连接在旧节点之间平衡
  • 旧节点已下线(一个接一个,以将每个节点的客户端数量保持在限制范围内)
  • 同时,新版本被部署到离线的“旧”节点上,并作为新节点启动
  • 由于 EJB 集群, session 和 bean 被其他旧节点拾取
  • 最终(几个小时后),只剩下一个旧节点,有一个旧版本的实例,所有使用旧版本的客户端都连接到它
  • 当最后一个旧客户端断开连接时,该节点也被关闭了

现在,我不是网络专家,无法为您提供很多细节(例如路由器硬件等)。据我所知,这可以很容易地设置,除了,如果我没记错的话,我们必须设置一个额外的 Weblogic 域来部署新版本的应用程序(否则它会与 JNDI 名称上的旧版本发生冲突)。

希望对您有所帮助。

附言Ichorus 提供了一条评论,称该应用程序部署在客户的服务器上。所以路由器技巧可能不可行。现在,我现在只看到一个可行的解决方案(现在是 21:52,我可能会忽略一些事情:))——

  • 开发具有“版本化”JNDI 名称的新版本;例如如果客户 bean 在版本 1 中位于 ejb/Customer 下,则在版本 2 中它将位于 ejb/Customer2 下
  • 在具有稳定基本接口(interface)(工厂风格)的应用程序中拥有一个业务门面,当要求客户 bean 时,它会尝试找到版本最高的 JNDI 名称(当然不是每次调用都可以缓存一个小时左右)。该外观可以(并且应该)作为单独的应用程序进行部署——并且永远不会或很少更新
  • 现在每个新客户都可以访问最新部署的应用程序,并且应用程序不会发生冲突。

此方法需要仔细规划和测试,但恕我直言应该可行。

我最近以类似的方式修改了一些应用程序,让它们在同一个域中共存(在它们对不同的数据源使用相同的 JNDI 名称之前)。

关于java - 热部署 Java EAR 以最小化或消除服务器上应用程序的停机时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/221846/

有关java - 热部署 Java EAR 以最小化或消除服务器上应用程序的停机时间?的更多相关文章

  1. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  2. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  3. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  4. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  5. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  6. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  7. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  8. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  9. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  10. ruby-on-rails - Ruby 检查日期时间是否为 iso8601 并保存 - 2

    我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby​​是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查

随机推荐