日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

Java应用中使用ShutdownHook友好地清理现场(转)

發(fā)布時(shí)間:2025/7/14 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java应用中使用ShutdownHook友好地清理现场(转) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

  在線上Java程序中經(jīng)常遇到進(jìn)程程掛掉,一些狀態(tài)沒有正確的保存下來(lái),這時(shí)候就需要在JVM關(guān)掉的時(shí)候執(zhí)行一些清理現(xiàn)場(chǎng)的代碼。Java中得ShutdownHook提供了比較好的方案。
  JDK在1.3之后提供了Java Runtime.addShutdownHook(Thread hook)方法,可以注冊(cè)一個(gè)JVM關(guān)閉的鉤子,這個(gè)鉤子可以在以下幾種場(chǎng)景被調(diào)用:

  • 1)程序正常退出
  • 2)使用System.exit()
  • 3)終端使用Ctrl+C觸發(fā)的中斷
  • 4)系統(tǒng)關(guān)閉
  • 5)使用Kill pid命令干掉進(jìn)程

注:在使用kill -9 pid是不會(huì)JVM注冊(cè)的鉤子不會(huì)被調(diào)用。
在JDK中方法的聲明:
public void addShutdownHook(Thread hook)
參數(shù)
hook -- 一個(gè)初始化但尚未啟動(dòng)的線程對(duì)象,注冊(cè)到JVM鉤子的運(yùn)行代碼。
異常
IllegalArgumentException -- 如果指定的鉤已被注冊(cè),或如果它可以判定鉤已經(jīng)運(yùn)行或已被運(yùn)行
IllegalStateException -- 如果虛擬機(jī)已經(jīng)是在關(guān)閉的過(guò)程中
SecurityException -- 如果存在安全管理器并且它拒絕的RuntimePermission(“shutdownHooks”)

代碼示例:
使用Timer模擬一個(gè)工作線程,該線程重復(fù)工作十次,使用System.exit()退出,在清理現(xiàn)場(chǎng)代碼CleanWorkThread 中,取消timer運(yùn)行,并輸出必要的日志信息。

package com.netease.test.java.lang;import java.util.Timer; import java.util.TimerTask; import java.util.concurrent.atomic.AtomicInteger;/*** Date: 14-6-18* Time: 11:01* 測(cè)試ShutdownHook*/ public class TestShutdownHook {//簡(jiǎn)單模擬干活的static Timer timer = new Timer("job-timer");//計(jì)數(shù)干活次數(shù)static AtomicInteger count = new AtomicInteger(0);/*** hook線程*/static class CleanWorkThread extends Thread{@Overridepublic void run() {System.out.println("clean some work.");timer.cancel();try {Thread.sleep(2 * 1000);//sleep 2s} catch (InterruptedException e) {e.printStackTrace();}}}public static void main(String[] args) throws InterruptedException {//將hook線程添加到運(yùn)行時(shí)環(huán)境中去Runtime.getRuntime().addShutdownHook(new CleanWorkThread());System.out.println("main class start ..... ");//簡(jiǎn)單模擬timer.schedule(new TimerTask() {@Overridepublic void run() {count.getAndIncrement();System.out.println("doing job " + count);if (count.get() == 10) { //干了10次退出System.exit(0);}}}, 0, 2 * 1000);} }

?



運(yùn)行后,可以模擬以上五種場(chǎng)景進(jìn)行測(cè)試,只有kill -9 pid不會(huì)執(zhí)行Hook里面的代碼。

http://www.cnblogs.com/nexiyi/p/java_add_ShutdownHook.html

總結(jié)

以上是生活随笔為你收集整理的Java应用中使用ShutdownHook友好地清理现场(转)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。