繁体   English   中英

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

[英]Hot Deploy a Java EAR to Minimize or Eliminate Downtime of an Application on a Server?

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

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

一旦我工作的公司有类似的问题,它就这样解决了:

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

现在,我不是一个网络人,也不能给你很多细节(比如什么是路由器硬件等)。 我的理解可以很简单,但是,如果我没记错的话,我们必须设置一个额外的Weblogic域来部署应用程序的新版本(否则它将与JNDI名称上的旧版本冲突)。

希望有所帮助。

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

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

这种方法需要仔细规划和测试,但应该工作恕我直言。

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

据我所知,WebLogic有一个称为并行部署的功能,可以消除EAR版本升级期间的停机时间。 您可以在不停止现有应用程序的情况下部署新版本,并且在成功部署新版本后,您可以透明地从旧版本切换到新版本。

我不确定其他应用程序服务器是否支持此功能。

参考: http://edocs.bea.com/wls/docs100/deployment/redeploy.html#wp1022490

弗拉基米尔关于使用负载均衡器的建议是实现你想要的非常可靠的方法。 请记住,它不一定是高端硬件负载平衡器。 相反,如果您使用本机Web服务器(Apache或IIS)和mod_jk或mod_proxy来安装JBoss服务器,则可以维护一个公共Web外观并在EAR升级时实现适用的加载和路由例程。

//尼古拉斯

我想你可能想要使用OSGI框架来研究Spring。 http://www.springframework.org/osgi

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM