一尘不染

如何编写可以在运行时进行自我更新的Java应用程序?

java

我想实现一个Java应用程序(服务器应用程序),该应用程序可以从给定的URL下载新版本(.jar文件),然后在运行时进行自身更新。

最好的方法是什么,有可能吗?

我猜该应用程序可以下载一个新的.jar文件并启动它。但是我应该如何进行切换,例如知道何时启动新应用程序然后退出。还是有更好的方法来做到这一点?


阅读 325

收藏
2020-03-16

共1个答案

一尘不染

解决方案的基本结构如下:

  • 有一个主循环负责重复加载应用程序的最新版本(如果需要)并启动它。

  • 该应用程序会执行其操作,但会定期检查下载URL。如果检测到新版本,它将返回启动器。

你可以通过多种方法来实现此目的。例如:

  • 启动器可以是包装脚本或二进制应用程序,它可以启动新的JVM,以从被替换的JAR文件中运行该应用程序。

  • 启动器可以是Java应用程序,它为新的JAR创建类加载器,加载入口点类并在其上调用一些方法。如果以这种方式这样做,则必须注意类加载器存储泄漏,但这并不困难。(你只需要确保重新启动后,无法访问带有从JAR加载的类的对象即可。)

外部包装方法的优点是:

  • 你只需要一个JAR,
  • 你可以替换整个Java应用程序,
  • 应用程序等创建的所有辅助线程将消失,而无需特殊的关闭逻辑,并且
  • 你还可以处理从应用程序崩溃等中恢复。

第二种方法需要两个JAR,但具有以下优点:

  • 该解决方案是纯Java且可移植的,
  • 转换将更快,并且
  • 你可以更轻松地在重新启动期间保留状态(模泄漏问题)。

“最佳”方式取决于你的特定要求。

还应注意:

  • 自动更新存在安全风险。通常,如果提供更新的服务器受到威胁,或者提供更新的机制容易受到攻击,则自动更新可能会导致客户机的损害。

  • 向客户推送导致损坏客户的更新可能会带来法律风险,也可能会损害你的企业声誉。

如果你能找到避免重新发明轮子的方法,那将是很好的。请参阅其他答案以获取建议。

2020-03-16