精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

不懂優雅停機,搞掛了線上服務該咋辦?

運維 新聞
我們所說的優雅停機,就是利用 Java 提供的 ShutdownHook 接口注冊一個鉤子,讓 JVM 在關閉之前執行鉤子函數的代碼,讓其關閉對應的資源。

公司項目是用 consul 進行注冊的,在發布微服務的時候,總是會導致調用方出現一定幾率的調用失敗。一開始百思不得其解,后來咨詢了資深的同事才知道:原來是服務下線的時候沒有優雅停機,沒有去 consul 將自己下線再停機,導致調用方拿到了舊的調用地址,導致調用失??! 看來優雅停機還是一個蠻重要的知識點,可不能忽略,今天就讓我們來盤盤它吧!

一、什么是優雅停機?

在 Linux 世界里,一切都是資源。當我們啟動一個 JVM 的時候,我們就加載了許多的資源。而當我們關閉 JVM 的時候,JVM 只會釋放內存這個資源,而其他資源是不會釋放的,例如:網絡連接、文件句柄等等。

Linux 的網絡連接數、文件句柄數都是有限的,如果我們沒有及時釋放,時間久了就會導致一些奇怪的問題。那么如何在 JVM 關閉的時候,釋放這些資源呢?答案就是:利用 Java 提供的 ShutdownHook 接口。 我們所說的優雅停機,就是利用 Java 提供的 ShutdownHook 接口注冊一個鉤子,讓 JVM 在關閉之前執行鉤子函數的代碼,讓其關閉對應的資源。

二、適用場景

在學會怎么使用優雅停機之前,我們需要弄清楚優雅停機適用于哪些場景,那我們就需要先弄清楚 JVM 關閉的幾種情況了。JVM 關閉的情況可以分為 3 大類 11 個情況,如下圖所示:

圖片

JVM 關閉的場景

在 JVM 關閉的 3 大類場景中,只有正常關閉與異常關閉是支持優雅停機的,而強制關閉則是不支持的。下面我們通過三個例子來驗證一下。

1、JVM 正常關閉

JVM 正常關閉這種情況,我們只需要正常運行一個 main 函數,然后為其注冊一個 ShutdownHook 即可,其代碼如下所示。

public class NormalShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數被執行,可以在這里關閉資源。")
));
}

public static void main(String[] args) {
new NormalShutdownTest().start();
System.out.println("主應用程序在執行,正常關閉。");
}
}

輸出結果為:

主應用程序在執行,正常關閉。
鉤子函數被執行,可以在這里關閉資源。

可以看到鉤子函數的代碼正常執行了。如果你在 main 函數增加 System.exit(0) 代碼,執行之后的結果也還是一樣。這說明 JVM 正常關閉情況下,是支持優雅停機的。

2、異常關閉

JVM 異常關閉這種情況,我們嘗試制造內存溢出。只需要聲明一個 500 MB 的數組,然后設置 JVM 堆最大為 20 MB 即可(-Xmx20M),其代碼如下所示。

public class OomShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數被執行,可以在這里關閉資源")
));
}

public static void main(String[] args) throws Exception {
new OomShutdownTest().start();
System.out.println("主應用程序在執行,內存溢出關閉。");
byte[] b = new byte[500 * 1024 * 1024];
}
}

執行結果為:

主應用程序在執行,內存溢出關閉。
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at tech.shuyi.javacodechip.shutdownhook.OomShutdownTest.main(OomShutdownTest.java:13)
鉤子函數被執行,可以在這里關閉資源

可以看到 JVM 拋出了 OOM 錯誤,但是鉤子函數還是被執行了。如果你在 main 函數中自行拋出 RuntimeException,鉤子函數也還是會被執行。感興趣的朋友可以自行嘗試一下。

3、強制關閉

JVM 強制關閉這種情況,我們可以使用 Runtime.getRuntime().halt(1) 進行測試,其代碼如下所示。

public class ForceShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數被執行,可以在這里關閉資源。")
));
}

public static void main(String[] args) throws Exception {
new ForceShutdownTest().start();
System.out.println("主應用程序在執行,強制關閉。");
Runtime.getRuntime().halt(1);
}
}

執行結果:

主應用程序在執行,強制關閉。

可以看到鉤子函數并沒有被執行,所以 JVM 強制關閉這種場景不支持優雅停機。

三、最佳實踐

看了上面的例子,看起來優雅停機沒那么復雜嘛。實際上,優雅停機用不好,很可能出現一些其他問題。這里給出幾個最佳實踐原則,幫助大家用好優雅停機!

1、只注冊一個鉤子

我們都知道 JVM 可以注冊多個鉤子,而鉤子本質上是一個線程,可以并發執行。那么就很可能出現鉤子之間相互依賴,這樣就會導致依賴死鎖了。另外,也可能因為多個鉤子操作同一個資源,導致資源競爭出現死鎖。因此,較好的一種方式就是只注冊一個鉤子,所有的資源釋放都在這個鉤子中操作。

2、確保線程安全

因為鉤子本質上也是一個線程,JVM 可能會并發執行多個鉤子,JVM 并不保證它們的執行順序,因此需要保證鉤子中的操作是線程安全的。當然了,如果你只有一個鉤子的話,那這個提示可以忽略了。

3、不要做耗時的操作

在鉤子中,不要做耗時的操作。因為當我們要關閉 JVM 時,用戶肯定是希望盡快關閉,因此鉤子中主要用于關閉殘留資源,不應該再做其他耗時的操作。

4、不要做注冊、移除鉤子的操作

在關閉鉤子中,不能執行注冊、移除鉤子的操作,否則 JVM 拋出 IllegalStateException。

5、不要調用 System.exit () 操作

也不能調用 System.exit ()  操作,但是調用 Runtime.halt() 操作是可以的。我想,這是因為調用 System.exit () 操作會導致循環進入鉤子,導致死循環吧。

6、需要考慮的資源

除了上面一些代碼上的操作需要考慮,我們還需要注意下面這些場景的處理:

池化資源的釋放:數據庫連接池、HTTP 連接池、線程池。

在處理線程的釋放:已經被連接的 HTTP 請求。

MQ 消費者的處理:正在處理的消息。

隱形受影響的資源的處理:Zookeeper、Nacos 實例下線等。

四、應用案例

Java 提供的優雅停機機制,可以說是許多框架的基礎。諸如 Spring、Consul 等中間件框架,都是利用 Java 提供的這個機制進行優雅停機的。

1、Spring 的優雅停機

例如 Spring 是基于 Java 語言開發的框架,那其也勢必依賴于 JVM 的 ShutdownHook。Spring 關于優雅停機的代碼在 org.springframework.context.support.AbstractApplicationContext#registerShutdownHook 處,代碼如下圖所示。

@Override
public void registerShutdownHook() {
if (this.shutdownHook == null) {
// No shutdown hook registered yet.
this.shutdownHook = new Thread(SHUTDOWN_HOOK_THREAD_NAME) {
@Override
public void run() {
synchronized (startupShutdownMonitor) {
doClose();
}
}
};
// 增加 ShutdownHook 鉤子
Runtime.getRuntime().addShutdownHook(this.shutdownHook);
}
}

可以看到 Spring 在 registerShutdownHook() 函數里,注冊了一個關閉的鉤子,鉤子中調用了 doClose() 方法。

2、服務治理的優雅停機

不論是 Dubbo 還是 Spring Cloud 的分布式服務框架,需要關注的是怎么能在服務停止前,先將提供者在注冊中心進行反注冊,然后在停止服務提供者,這樣才能保證業務系統不會產生各種 503、timeout 等現象。為了實現上述說到的效果,那么我們就必須關注優雅停機這件事情。

彩蛋

我們都知道通過 kill -15 可以讓 JVM 優雅停機,那我們是否可以監聽特定的信號量,從而讓程序做特定的操作呢?例如:讓 JVM 監聽第 12 信號量,然后打印一條日志,隨后優雅停機。

答案是當然可以啦!我們只需要利用 Signal 類,并實現一個 SignHandler 類就可以了。其實現代碼如下所示:

public class CustomShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數被執行,可以在這里關閉資源。")
));
}

public static void main(String[] args) {
// custom signal kill
Signal sg = new Signal("USR2"); // kill -12 pid
Signal.handle(sg, new SignalHandler() {
@Override
public void handle(Signal signal) {
System.out.println("接收到信號量:" + signal.getName());
// 監聽信號量,通過System.exit(0)正常關閉JVM,觸發關閉鉤子執行收尾工作
System.exit(0);
}
});
// other logic
new CustomShutdownTest().start();
System.out.println("主應用程序在執行,正常關閉。");
try {
Thread.sleep(30000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

我們啟動該類后,先讓其休眠 30 秒,隨后用 jps 命令找到進程 ID,隨后運行 kill -USR2 PID 即可,如截圖所示。

圖片

隨后可以看到控制臺打印出如下消息:

主應用程序在執行,正常關閉。
接收到信號量:USR2
鉤子函數被執行,可以在這里關閉資源。

從上面消息我們知道,JVM 成功接收到了 USR2 信號量,也成功執行了鉤子函數。搞定!

提示:其實 USR2 是 Linux 第 12 個信號量,是留給用戶使用的一個信號量。我們可以通過該信號量做一些定制化操作,從而實現更加復雜的功能。

責任編輯:張燕妮 來源: dbaplus社群
相關推薦

2022-06-08 08:06:05

LinuxJVM內存

2025-07-29 08:25:57

2021-10-03 15:00:44

數據庫mysql單機

2021-05-08 08:33:00

Rocketmq日志數據源

2021-04-19 09:37:12

RocketMQ集群版本

2023-01-30 07:41:43

2020-08-25 10:34:22

微服務微服務架構生產環境

2025-03-17 00:00:00

2024-03-18 14:06:00

停機Spring服務器

2020-08-03 07:04:54

測試面試官應用程序

2025-03-11 00:55:00

Spring停機安全

2021-08-02 15:06:46

vim服務Java

2011-11-18 16:41:42

IDC世紀互聯

2021-02-06 13:11:28

SQL系統數據庫

2019-10-18 15:07:14

數據科學職業生涯萬努克

2021-06-10 06:59:34

Redis應用API

2020-10-14 10:29:58

人工智能

2009-04-24 08:26:02

Mobile Mark移動OS

2018-11-01 13:38:51

Java中斷停止

2024-07-22 19:31:34

點贊
收藏

51CTO技術棧公眾號

欧美激情一区二区三区在线视频观看| 欧美精品第一页| 欧美日韩亚洲一区二区三区四区| 中文字幕黄色片| re久久精品视频| 欧美一区二区三区在线电影| 欧美视频在线免费播放| shkd中文字幕久久在线观看| 国产麻豆视频精品| 97超碰色婷婷| 久久嫩草捆绑紧缚| 麻豆视频一区| 在线成人免费观看| 91精品91久久久中77777老牛 | 欧美www视频| 国产xxxxx视频| 色婷婷在线播放| 国产夜色精品一区二区av| 91在线观看免费高清| 国产精品21p| 欧美片第1页综合| 一区二区欧美亚洲| 国产伦精品一区三区精东| 国产成人77亚洲精品www| 亚洲一区二区av电影| 亚洲成人自拍视频| 无码精品黑人一区二区三区| 久久99精品久久久久久动态图| 97国产suv精品一区二区62| 又色又爽的视频| 亚洲人成网www| 欧美大片在线观看| 在线观看av日韩| 欧美xxxhd| 亚洲自拍偷拍综合| 中文字幕久久综合| 国产高清视频在线观看| 97精品国产露脸对白| 99久久精品久久久久久ai换脸| 中文字幕免费观看视频| 久久中文精品| 91av在线精品| 日本一级片免费看| 欧美三区在线| 欧美黑人极品猛少妇色xxxxx| 乱老熟女一区二区三区| 欧美理论在线播放| 亚洲欧美精品一区| 亚洲国产精品成人综合久久久| 色悠久久久久综合先锋影音下载| 9191久久久久久久久久久| 无码少妇一区二区三区芒果| 成人性教育av免费网址| 日韩欧美一区二区三区| 国产3p露脸普通话对白| hd国产人妖ts另类视频| 亚洲国产一区二区三区| 国产91沈先生在线播放| 欧美78videosex性欧美| 一片黄亚洲嫩模| 欧美日韩视频免费| 日本三级在线观看网站| 夜夜精品视频一区二区| 丁香婷婷综合激情| 91www在线| 欧美日韩国产一区二区| 日韩av一二三四区| 日韩精品一区二区三区| 欧美三级欧美一级| 一级做a免费视频| 免费看一区二区三区| 日韩欧美一级在线播放| 中文视频在线观看| 亚洲免费福利一区| 中文字幕少妇一区二区三区| 国产日产在线观看| 欧美日韩岛国| 3344国产精品免费看| 超碰在线观看91| 韩国v欧美v亚洲v日本v| 国产精品久久波多野结衣| 天堂av2024| 久久久91精品国产一区二区精品 | 青青视频在线观| 久久久久久毛片| 一区二区三区av在线| 伊人手机在线| 都市激情亚洲色图| 天天操,天天操| 日韩精品视频中文字幕| 日韩成人小视频| www久久久久久久| 综合色一区二区| 欧美一级淫片aaaaaaa视频| 最新黄色网址在线观看| 国产高清久久久| 欧洲在线视频一区| 最新黄网在线观看| 色婷婷综合久久久中文字幕| 涩涩网站在线看| 男人的天堂久久| 日韩在线中文视频| 日韩黄色一级大片| 国产在线观看一区二区| 玖玖玖精品中文字幕| 麻豆tv免费在线观看| 香蕉av福利精品导航| jizz欧美性11| 日韩电影不卡一区| 成人97在线观看视频| 日本中文字幕在线观看视频| 国产精品一二一区| 日韩精品av一区二区三区| 国产成人无吗| 欧美亚洲一区二区在线观看| www男人天堂| 999国产精品| 久久免费福利视频| 国产精品探花视频| 久久精品亚洲精品国产欧美| 日本免费a视频| 24小时成人在线视频| 亚洲人成电影在线观看天堂色| 久草成人在线视频| 国产一区二三区| 亚洲最大色综合成人av| 成人国产二区| 亚洲精品成人久久| 麻豆亚洲av熟女国产一区二| 狠狠色综合色综合网络| 日韩免费一区二区三区| 亚洲黄色中文字幕| 亚洲国产精品va在线观看黑人| tube国产麻豆| 久久99久久久久久久久久久| 色一情一乱一伦一区二区三欧美 | 精品国产成人av| 男人女人拔萝卜视频| 国产精品成人a在线观看| 全球成人中文在线| 亚洲色图另类小说| 精品动漫一区二区| 中国xxxx性xxxx产国| 亚洲午夜黄色| 国产高清不卡av| 国产一线二线在线观看| 日韩一区二区影院| 欧美一区二区三区爽爽爽| 激情综合色综合久久| 一区二区av| 亚洲国产伊人| 精品久久久91| 99久久免费国产精精品| 亚洲男人天堂av| 色哟哟免费视频| 欧美亚韩一区| 国产一区二区三区四区五区在线| 2020av在线| 亚洲精品www久久久| 日韩免费不卡视频| 91在线码无精品| 男人天堂网视频| 国产成人调教视频在线观看 | 日韩在线视频免费观看| 91tv国产成人福利| 亚洲老司机在线| 一级全黄裸体片| 日韩视频二区| 久久一区二区三区av| 色多多在线观看| 亚洲视频网站在线观看| 最新黄色网址在线观看| 亚洲婷婷综合久久一本伊一区| jizz18女人| 国产精品二区影院| 久久久久久国产精品mv| 在线成人视屏 | www.com.av| 国产成人综合在线| 黄色片视频在线免费观看| 免费久久精品| 92国产精品久久久久首页| 美足av综合网| 亚洲一区二区福利| 国产高潮在线观看| 日韩欧美在线国产| 国产精品免费在线视频| 粉嫩av一区二区三区粉嫩 | 乱人伦视频在线| 国产一区二区三区视频在线观看| 国产又粗又猛又爽又黄的视频一| 亚洲午夜私人影院| 女人黄色一级片| 高清久久久久久| 国内自拍视频网| 很黄很黄激情成人| 色就是色欧美| 免费成人蒂法| 成人免费自拍视频| 亚洲最大网站| 九九视频直播综合网| 丰满熟妇乱又伦| 亚洲超碰精品一区二区| 99久久久无码国产精品不卡| 9i在线看片成人免费| 中文字幕一区久久| 久久电影一区| a级黄色小视频| 青青草成人影院| 精品不卡在线| 欧美三级一区| 国产精品久久久久久久久久久久久久 | 日韩精品一区二区三区国语自制| 中文字幕一区二区三区av| 亚洲国产精品成人综合久久久| 精品亚洲欧美一区| 成年人在线看片| 精品动漫3d一区二区三区免费| 亚洲精品中字| 首页亚洲中字| 超碰97在线资源| 91精品在线免费视频| 日本不卡高字幕在线2019| 免费毛片在线看片免费丝瓜视频| 日日骚av一区| 粉嫩一区二区三区国产精品| 日韩福利视频在线观看| 亚洲黄色在线观看视频| 欧美一区永久视频免费观看| 波多野结衣视频网址| 欧美日韩国产一区二区| 国产 日韩 欧美 成人| 亚洲精品国产品国语在线app| 成人无码av片在线观看| 久久久久久久av麻豆果冻| 亚洲观看黄色网| jvid福利写真一区二区三区| 国产女主播在线播放| 黑人巨大精品欧美一区| 成人性生交免费看| 免费观看在线色综合| 国产xxxxx视频| 日韩专区中文字幕一区二区| aa在线免费观看| 亚洲综合欧美| 午夜精品久久久内射近拍高清| 在线日本成人| 国产午夜大地久久| 男女精品网站| 国产视频一区二区三区在线播放 | 91精品国产91久久久久久久久 | 人妻少妇精品无码专区| 精品国产欧美一区二区| 亚洲AV无码精品色毛片浪潮| 日韩一区二区影院| 亚洲经典一区二区| 亚洲第一色在线| 手机在线精品视频| 日韩精品黄色网| 毛片在线播放网址| 一区二区成人av| 欧美尤物美女在线| 久久午夜a级毛片| 丝袜综合欧美| 久久久之久亚州精品露出| av丝袜在线| 欧美一区二区三区免费观看| 欧美激情喷水| 成人激情黄色网| 亚洲小说春色综合另类电影| 国产精品久久久对白| 亚洲人和日本人hd| 亚洲美女搞黄| 欧美伊人影院| 免费一级特黄特色毛片久久看| 老牛影视一区二区三区| 不卡的在线视频| 成人丝袜高跟foot| 色婷婷在线影院| 最新中文字幕一区二区三区| 国产真实乱偷精品视频| 色8久久人人97超碰香蕉987| 一级黄色大片免费| 亚洲精品一区二区三区99| 欧美视频综合| 久久视频免费观看| 神马午夜在线视频| 国产精品久在线观看| 一区二区三区国产好| 色一情一区二区三区四区 | www国产黄色| 精品中文av资源站在线观看| 在线xxxxx| 中文天堂在线一区| 国产乡下妇女做爰| 欧美日韩午夜在线视频| 色婷婷在线视频| 日韩中文娱乐网| 色资源二区在线视频| 91免费福利视频| 亚洲自拍都市欧美小说| 日本精品福利视频| 日本大胆欧美人术艺术动态| 韩国黄色一级片| 国产精品二三区| 日日摸天天添天天添破| 欧美一级二级三级乱码| 国产理论电影在线观看| 97国产在线观看| 国产精品日本一区二区不卡视频| 欧美久久久久久一卡四| 国产一区二区三区四区老人| 艹b视频在线观看| 91色在线porny| 精品爆乳一区二区三区无码av| 欧美色爱综合网| 欧美色18zzzzxxxxx| 国产69精品99久久久久久宅男| 亚洲国产91视频| 日本在线播放一区| 亚洲综合不卡| 中国一级特黄录像播放| 一区二区高清在线| 国产又粗又猛视频免费| 综合久久五月天| 成人免费毛片嘿嘿连载视频…| 久久久99爱| 国产日韩欧美三区| 大尺度在线观看| 亚洲综合久久av| www.爱爱.com| 久久av.com| 国产精久久久| 一本二本三本亚洲码| 久久99精品国产.久久久久久| 久久只有这里有精品| 精品欧美国产一区二区三区| 蜜桃av中文字幕| 国内精品久久影院| 北条麻妃一区二区三区在线观看| 国产激情在线看| 国产老肥熟一区二区三区| 免费三级在线观看| 欧美久久久久久久久久| 日本中文字幕伦在线观看| 国产精品爽黄69天堂a| 日本不卡免费一区| 五月婷婷之婷婷| 亚洲三级理论片| 精品久久国产视频| 久久久久久久一区二区三区| 亚洲乱码一区| 国产va亚洲va在线va| av电影在线观看一区| 天天操夜夜操视频| 在线免费看av不卡| www999久久| www.好吊操| 久久综合九色综合97婷婷| 一级片免费在线播放| 一本色道久久综合狠狠躁篇的优点| 日本.亚洲电影| 在线免费观看一区二区三区| 激情亚洲综合在线| 久久黄色小视频| 日韩大陆欧美高清视频区| www.日韩| 一本一本久久a久久精品综合妖精| 久久成人免费日本黄色| 欧美日韩免费做爰视频| 亚洲第一视频在线观看| 在线看的毛片| 日韩av电影免费在线观看| 久久国产精品无码网站| 久久机热这里只有精品| 亚洲精品乱码久久久久久金桔影视| 电影一区二区三| www.午夜色| 99精品黄色片免费大全| 青青艹在线观看| 欧美激情第1页| 蜜桃tv一区二区三区| 日本网站在线看| 黄色成人在线免费| 在线免费观看的av网站| 成人看片在线| 青娱乐精品视频| 久久免费少妇高潮99精品| 亚洲午夜未删减在线观看 | 日韩视频在线永久播放| 亚洲精品日产| 麻豆md0077饥渴少妇| 91美女片黄在线| 国产口爆吞精一区二区| 69av在线视频| 天天综合亚洲| 日本激情小视频| 日韩精品一区二区三区在线| 456成人影院在线观看| 分分操这里只有精品|