溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot如何進行優(yōu)雅停服

發(fā)布時間:2021-09-29 17:00:09 來源:億速云 閱讀:329 作者:柒染 欄目:編程語言

SpringBoot如何進行優(yōu)雅停服,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、介紹

        當外部流量請求到服務端接口執(zhí)行業(yè)務邏輯的時候,若服務端此時執(zhí)行關機 (kill),spring boot 默認情況會直接關閉容器(tomcat 等),導致此業(yè)務邏輯執(zhí)行失敗。在一些業(yè)務場景下:會出現數據不一致的情況,事務邏輯不會回滾。

        在最新的 spring boot 2.3 版本,內置此功能,不需要再自行擴展容器線程池來處理, 目前 spring boot 嵌入式支持的 web 服務器(Jetty、Reactor Netty、Tomcat 和 Undertow)以及反應式和基于 Servlet 的 web 應用程序都支持優(yōu)雅停機功能。

SpringBoot如何進行優(yōu)雅停服

        此處支持的 shutdown 行為,我們看下源碼枚舉如下:

public enum Shutdown {
 /**
  * 優(yōu)雅停機 (限期停機)
  *
  */
 GRACEFUL,

 /**
  * 立即停機
  */
 IMMEDIATE;

}

二、使用

        當使用server.shutdown=graceful啟用時,在 web 容器關閉時,web 服務器將不再接收新請求,并將等待活動請求完成的緩沖期。

        緩沖期 timeout-per-shutdown-phase 配置:默認時間為 30S, 意味著最大等待 30S,超時候無論線程任務是否執(zhí)行完畢都會停機處理,一定要根據項目實際需要合理設置。

SpringBoot如何進行優(yōu)雅停服

        以上配置完畢,重新發(fā)布以后,服務端就支持優(yōu)雅停服。

三、觸發(fā)優(yōu)雅停服

1、對進城PID執(zhí)行kill -2 而不是 kill -9 


        kill -9,暴力美學強制殺死進程,不會執(zhí)行 ShutdownHook;但是 kill -2 相當于快捷鍵 Ctrl + C 會觸發(fā) Java 的 ShutdownHook 事件處理進行優(yōu)雅停機或者一些后置處理??蓞⒖家韵略创a:

 

 @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);
  }
 }

2、通過 actuate 端點實現優(yōu)雅停機

        POST 請求 /actuator/shutdown 即可執(zhí)行優(yōu)雅關機。源碼解析如下:

@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();
 }
}

三、不同spring boot嵌入式 web 容器優(yōu)雅停機行為區(qū)別

SpringBoot如何進行優(yōu)雅停服

看完上述內容,你們掌握SpringBoot如何進行優(yōu)雅停服的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI