前言
首先什么是优雅关机?关机大家应该都明白,即将程序停止,像手机的关机一样,直接关闭。那如何理解关机前面加上优雅呢?优雅关机其实是指当执行关机信号的时候,并不会直接关机,而是先将原来正在进行的线程逻辑,处理完成后再退出程序。
为什么一个优秀的软件系统需要设计优雅关机呢?
首先我们看一个例子,日常大家在使用 Windows 电脑的时候,有时候会出现蓝屏的情况。尤其是在编写文件的过程中,并没有及时进行保存操作,很容易出现文件丢失,重启后,发现前功尽弃。
如果我们执行正常的关机操作,往往留给操作系统处理时间,可以做一些文件的保存的操作,常常会有如下提示:
可以取消此次关机操作,并保存相关程序的内容,再执行关机。虽然这个过程是需要人工操作,但原理相同,都是在执行关机操作后,作出相应的处理,只是 Windows 是提醒用户。
其实程序也是一样,如果当前程序正在执行数据库事务或者写文件等操作,执行关闭操作,很容易出现文件损坏、数据丢失等情况,因此一个优秀的系统,优雅关机也很重要。
目前优雅停机还没有通用的解决方案,常常我们需要根据具体的应用制定具体的策略,大致思路如下:
分析应用各组件的依赖关系
制定合理的关闭顺序
执行关闭操作时,拒绝新的请求策略
Java 优雅关机
那么 Java 的优雅关机如何操作呢?其实 Java 在 JDK 1.3 开始就提供了 Runtime.getRuntime().addShutdownHook() 方法来注册退出钩子,以保证程序平滑退出。