我们需要在Servlet应用程序中实现一个优雅的关闭机制。
编辑:我们希望尽可能简化,这将处理通过操作系统的功能发送的终止信号。这将允许系统管理员使用内置的shell实用程序(在Windows上执行kill或taskkill),否则他们必须安装另一个实用程序才能与服务器“对话”。
这种机制分两个阶段进行:
阶段#1在我们的DAO层中实现。 阶段#2在我们的ServletContextListener#contextDestroyed方法
中实现我们的问题是,一旦调用了contextDestroyed,Servlet容器就会停止为进一步的HTTP请求提供服务。
编辑:当有人在服务器进程上调用操作系统的kill函数时,会调用contextDestroyed。
我们希望在第2阶段让应用程序处于活动状态,通知用户某些活动不可用。
答案 0 :(得分:4)
使用filter保留所有关键请求的列表。
当收到“准备关闭”请求时,过滤器应该开始拒绝某些请求。
编写一个servlet,告诉您仍有多少关键作业留在队列中。
在关机工具中,发送“准备关机”。对servlet进行轮询以获取关键作业的数量。当它达到0时,发送实际的shutdown命令。
要实现这一点,请在业务层中创建一个服务于此的服务。请注意,在调用 contextDestroyed()
之前,一切都必须发生!您的特殊应用程序关闭不适合世界的J2EE视图,因此您必须自己管理它。
服务应该能够在关机正在进行时告诉感兴趣的各方,有多少关键作业仍在运行等等。然后,Servlet和过滤器可以使用此服务拒绝请求或告知剩余的作业数量。
当所有工作完成后,拒绝除了访问“关闭信息”servlet之外的所有请求,然后应该告诉应用程序现在已准备好死亡。
编写一个工具,为管理员提供一个很好的UI来启动应用程序的关闭。
[编辑] 您可能会想要阻止操作系统关闭您的应用程序。 不要这样做。
你应该做的是编写一个特殊的工具,使用我上面描述的两阶段过程来关闭你的应用程序。这应该是关闭的标准方法。
是的,管理员会抱怨它。在Unix上,您可以通过将其放入init脚本来隐藏此工具,因此没有人会注意到。 Windows上可能有类似的解决方案。
在(非)预期情况下(例如:关机代码中的错误,电源故障期间的紧急关机,应用程序代码中的错误或Murphy发生时),应始终能够停止服务器以阻止它。 / p>