博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java应用中使用ShutdownHook友好地清理现场
阅读量:5098 次
发布时间:2019-06-13

本文共 2192 字,大约阅读时间需要 7 分钟。

在线上Java程序中经常遇到进程程挂掉,一些状态没有正确的保存下来,这时候就需要在JVM关掉的时候执行一些清理现场的代码。Java中得ShutdownHook提供了比较好的方案。

  JDK在1.3之后提供了Java Runtime.addShutdownHook(Thread hook)方法,可以注册一个JVM关闭的钩子,这个钩子可以在以下几种场景被调用:

  • 1)程序正常退出
  • 2)使用System.exit()
  • 3)终端使用Ctrl+C触发的中断
  • 4)系统关闭
  • 5)使用Kill pid命令干掉进程

注:在使用kill -9 pid是不会JVM注册的钩子不会被调用。

在JDK中方法的声明:
public void addShutdownHook(Thread hook)
参数
hook -- 一个初始化但尚未启动的线程对象,注册到JVM钩子的运行代码。
异常
IllegalArgumentException -- 如果指定的钩已被注册,或如果它可以判定钩已经运行或已被运行
IllegalStateException -- 如果虚拟机已经是在关闭的过程中
SecurityException -- 如果存在安全管理器并且它拒绝的RuntimePermission(“shutdownHooks”)
代码示例:
使用Timer模拟一个工作线程,该线程重复工作十次,使用System.exit()退出,在清理现场代码CleanWorkThread 中,取消timer运行,并输出必要的日志信息。

 

1 package com.netease.test.java.lang; 2  3 import java.util.Timer; 4 import java.util.TimerTask; 5 import java.util.concurrent.atomic.AtomicInteger; 6  7 /** 8  * Date: 14-6-18 9  * Time: 11:0110  * 测试ShutdownHook11  */12 public class TestShutdownHook {13 14     //简单模拟干活的15     static Timer timer = new Timer("job-timer");16 17     //计数干活次数18     static AtomicInteger count = new AtomicInteger(0);19 20     /**21      * hook线程22      */23     static class CleanWorkThread extends Thread{24         @Override25         public void run() {26             System.out.println("clean some work.");27             timer.cancel();28             try {29                 Thread.sleep(2 * 1000);//sleep 2s30             } catch (InterruptedException e) {31                 e.printStackTrace();32             }33         }34     }35     public static void main(String[] args) throws InterruptedException {36         //将hook线程添加到运行时环境中去37         Runtime.getRuntime().addShutdownHook(new CleanWorkThread());38         System.out.println("main class start ..... ");39         //简单模拟40         timer.schedule(new TimerTask() {41             @Override42             public void run() {43                 count.getAndIncrement();44                 System.out.println("doing job " + count);45                 if (count.get() == 10) {  //干了10次退出46                     System.exit(0);47                 }48             }49         }, 0, 2 * 1000);50 51     }52 }

 

运行后,可以模拟以上五种场景进行测试,只有kill -9 pid不会执行Hook里面的代码。

 

转载于:https://www.cnblogs.com/shuo1208/p/5871224.html

你可能感兴趣的文章
关键字参数
查看>>
Python Cookbook(第2版)中文版
查看>>
TCP协议栈的6类定时器
查看>>
【图论 动态规划拆点】luoguP3953 逛公园
查看>>
【大话存储II】学习笔记(2章), SSD
查看>>
SQLHelp sql数据库的DAL
查看>>
阅读学术论文的心得体会from小木虫
查看>>
Python——Message控件
查看>>
多线程下单例模式:懒加载(延迟加载)和即时加载
查看>>
从 fn_dbLog 解析操作日志(补充update)
查看>>
JavaEE 数据库随机值插入测试
查看>>
this
查看>>
判断对象类型 type()
查看>>
Php函数之end
查看>>
腾讯AB题
查看>>
C# 实现冒泡算法--不一定效率,但很容易理解
查看>>
如何开发AR增强现实应用与产品
查看>>
C++中遍历lua table
查看>>
Python 编程快速上手 第 7章 模式匹配与正则表达式
查看>>
深度解析vuex
查看>>