9

我们需要在我们的 Servlet 应用程序中实现一个优雅的关闭机制。

编辑:我们想让它尽可能简单,这将处理通过操作系统功能发送的终止信号。这将允许系统管理员使用内置的 shell 实用程序(Windows 上的 kill 或 taskkill),否则他们必须安装另一个实用程序才能与服务器“对话”。

该机制分两个阶段起作用:

  1. 根据关闭请求,拒绝某些关键活动
  2. 阻塞,直到先前启动的关键操作完成;这些可能需要几个小时

阶段 #1 在我们的 DAO 层中实现。阶段 #2 在我们的 ServletContextListener#contextDestroyed 方法中实现

我们的问题是,一旦 contextDestroyed 被调用,Servlet 容器就会停止为进一步的 HTTP 请求提供服务。

编辑: contextDestroyed 当有人在服务器进程上调用操作系统的 kill 函数时被调用。

我们希望在第 2 阶段期间让应用程序处于活动状态,通知用户某些活动不可用。

4

1 回答 1

5

使用过滤器保留所有关键请求的列表。

当收到“准备关闭”请求时,过滤器应该开始拒绝一些请求。

编写一个 servlet,告诉您队列中还剩下多少关键作业。

在关机工具中,发送“准备关机”。轮询 servlet 以了解关键作业的数量。当此值达到 0 时,发送实际的关机命令。

为了实现这一点,请在业务层中创建一个服务来协调这一点。请注意,所有事情都必须在被调用之前发生! contextDestroyed()您的特殊应用程序关闭不适合 J2EE 的世界观,因此您必须自己管理它。

该服务应该能够告诉感兴趣的各方何时正在关闭,还有多少关键作业仍在运行等。Servlet 和过滤器可以使用该服务拒绝请求或告知剩余的作业数量。

当所有工作都完成后,拒绝所有请求,除了对“关闭信息”servlet 的访问,该 servlet 应该告诉应用程序现在已经准备好死亡。

编写一个工具,为管理员提供一个漂亮的 UI 来启动您的应用程序的关闭。

[编辑]您可能想阻止操作系统关闭您的应用程序。不要那样做。

你应该做的是编写一个特殊的工具来使用我上面描述的两阶段过程来关闭你的应用程序。这应该是标准的关机方式。

是的,管理员会抱怨它。在 Unix 上,您可以通过将其放入 init 脚本来隐藏此工具,因此不会有人注意到。Windows 上可能有类似的解决方案。

在以下(意外)情况下,终止服务器应该始终能够停止它:关闭代码中的错误、电源故障期间的紧急关闭、应用程序代码中的错误或墨菲发生时。

于 2013-08-26T13:29:04.787 回答