优雅停机

什么是优雅停机

应用服务器的停机主要分为两类:主动停机和被动停机,而其中主动停机和大部分的被动停机都是可以实现优雅停机。如果应用不做优雅停机,则会带来以下情况:

  • 数据丢失
  • 文件损坏
  • 请求丢失
  • 响应丢失
  • 交易中断
  • 服务未下线

优雅停机可以解决的场景

  • kill pid
  • 应用程序以外退出
  • 使用脚本方式停止应用

优雅停机不能解决的场景

  • 突然断电
  • 机器物理破坏
  • kill -9 pid
  • taskkill /f /pid

Java系统优雅停机原理

  • Java的优雅停机通常通过注册JDK的ShutdownHook(钩子)来实现,当系统接收到退出指令后,首先标记系统处于退出状态,不再接收新的消息,然后将积压的消息处理完,最后调用资源回收接口将资源销毁,最后各线程退出执行。
  • 通常优雅退出需要有超时控制机制,如果到达超时时间仍然没有完成退出前的资源回收等操作,则由停机脚本直接调用KILL -9 PID的方式进行强制退出,不然可能会等待很长时间。

已经支持优雅停机的Java中间件

  • Netty
  • Dubbo
  • ...
坚持原创技术分享,您的支持将鼓励我继续创作!
0%