您好,登錄后才能下訂單哦!
SpringBoot如何進行優雅停服,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
當外部流量請求到服務端接口執行業務邏輯的時候,若服務端此時執行關機 (kill),spring boot 默認情況會直接關閉容器(tomcat 等),導致此業務邏輯執行失敗。在一些業務場景下:會出現數據不一致的情況,事務邏輯不會回滾。
在最新的 spring boot 2.3 版本,內置此功能,不需要再自行擴展容器線程池來處理, 目前 spring boot 嵌入式支持的 web 服務器(Jetty、Reactor Netty、Tomcat 和 Undertow)以及反應式和基于 Servlet 的 web 應用程序都支持優雅停機功能。
此處支持的 shutdown 行為,我們看下源碼枚舉如下:
public enum Shutdown { /** * 優雅停機 (限期停機) * */ GRACEFUL, /** * 立即停機 */ IMMEDIATE; }
當使用server.shutdown=graceful啟用時,在 web 容器關閉時,web 服務器將不再接收新請求,并將等待活動請求完成的緩沖期。
緩沖期 timeout-per-shutdown-phase 配置:默認時間為 30S, 意味著最大等待 30S,超時候無論線程任務是否執行完畢都會停機處理,一定要根據項目實際需要合理設置。
以上配置完畢,重新發布以后,服務端就支持優雅停服。
kill -9,暴力美學強制殺死進程,不會執行 ShutdownHook;但是 kill -2 相當于快捷鍵 Ctrl + C 會觸發 Java 的 ShutdownHook 事件處理進行優雅停機或者一些后置處理。可參考以下源碼:
@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(); } } }; Runtime.getRuntime().addShutdownHook(this.shutdownHook); } }
POST 請求 /actuator/shutdown 即可執行優雅關機。源碼解析如下:
@Endpoint(id = "shutdown", enableByDefault = false) public class ShutdownEndpoint implements ApplicationContextAware { @WriteOperation public Map<String, String> shutdown() { Thread thread = new Thread(this::performShutdown); thread.setContextClassLoader(getClass().getClassLoader()); thread.start(); } private void performShutdown() { try { Thread.sleep(500L); } catch (InterruptedException ex) { Thread.currentThread().interrupt(); } // 此處close 邏輯和上邊 shutdownhook 的處理一樣 this.context.close(); } }
看完上述內容,你們掌握SpringBoot如何進行優雅停服的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。