如何在长时间关闭期间处理servlet请求

时间:2013-08-26 12:42:15

标签: java servlets

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

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

这种机制分两个阶段进行:

  1. 关闭请求时,拒绝某些关键活动
  2. 阻止,直到先前发起的关键行动完成;这些可能需要几个小时
  3. 阶段#1在我们的DAO层中实现。 阶段#2在我们的ServletContextListener#contextDestroyed方法

    中实现

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

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

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

1 个答案:

答案 0 :(得分:4)

使用filter保留所有关键请求的列表。

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

编写一个servlet,告诉您仍有多少关键作业留在队列中。

在关机工具中,发送“准备关机”。对servlet进行轮询以获取关键作业的数量。当它达到0时,发送实际的shutdown命令。

要实现这一点,请在业务层中创建一个服务于此的服务。请注意,在调用 contextDestroyed()之前,一切都必须发生!您的特殊应用程序关闭不适合世界的J2EE视图,因此您必须自己管理它。

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

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

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

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

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

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

在(非)预期情况下(例如:关机代码中的错误,电源故障期间的紧急关机,应用程序代码中的错误或Murphy发生时),应始终能够停止服务器以阻止它。 / p>