自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

面試官:SpringBoot如何優(yōu)雅停機?

開發(fā) 前端
不同的 Web 容器(Tomcat、Jetty、Undertow)有不同的自定義優(yōu)雅停機的方法,以 Tomcat 為例,它的自定義優(yōu)雅停機實現(xiàn)如下。

優(yōu)雅停機(Graceful Shutdown)是指在服務(wù)器需要關(guān)閉或重啟時,能夠先處理完當(dāng)前正在進行的請求,然后再停止服務(wù)的操作。

優(yōu)雅停機的實現(xiàn)步驟主要分為以下幾步:

  1. 停止接收新的請求:首先,系統(tǒng)會停止接受新的請求,這樣就不會有新的任務(wù)被添加到任務(wù)隊列中。
  2. 處理當(dāng)前請求:系統(tǒng)會繼續(xù)處理當(dāng)前已經(jīng)在處理中的請求,確保這些請求能夠正常完成。這通常涉及到等待正在執(zhí)行的任務(wù)完成,如處理HTTP請求、數(shù)據(jù)庫操作等。
  3. 釋放資源:在請求處理完成后,系統(tǒng)會釋放所有已分配的資源,如關(guān)閉數(shù)據(jù)庫連接、斷開網(wǎng)絡(luò)連接等。
  4. 關(guān)閉服務(wù):最后,當(dāng)所有請求都處理完畢且資源都已釋放后,系統(tǒng)會安全地關(guān)閉服務(wù)。

0.SpringBoot如何實現(xiàn)優(yōu)雅停機?

優(yōu)雅停機的實現(xiàn)步驟分為以下兩步:

  1. 使用合理的 kill 命令,給 Spring Boot 項目發(fā)送優(yōu)雅停機指令。
  2. 開啟 Spring Boot 優(yōu)雅停機/自定義 Spring Boot 優(yōu)雅停機的實現(xiàn)。

1.合理殺死進程

在 Linux 中 kill 殺死進程的常用命令有以下這些:

  1. kill -2 pid:向指定 pid 發(fā)送 SIGINT 中斷信號,等同于 ctrl+c。也就說,不僅當(dāng)前進程會收到該信號,而且它的子進程也會收到終止的命令。
  2. kill -9 pid:向指定 pid 發(fā)送 SIGKILL 立即終止信號。程序不能捕獲該信號,最粗暴最快速結(jié)束程序的方法。
  3. kill -15 pid:向指定 pid 發(fā)送 SIGTERM 終止信號。信號會被當(dāng)前進程接收到,但它的子進程不會收到,如果當(dāng)前進程被 kill 掉,它的的子進程的父進程將變成 init 進程 (init 進程是那個 pid 為 1 的進程)。
  4. kill pid:等同于 kill 15 pid。

因此,在以上命令中,我們不能使用“kill -9”來殺死進程,使用“kill”殺死進程即可。

2.設(shè)置SpringBoot優(yōu)雅停機

在 Spring Boot 2.3.0 之后,可以通過配置設(shè)置開啟 Spring Boot 的優(yōu)雅停機功能,如下所示:

# 開啟優(yōu)雅停機,默認值:immediate 為立即關(guān)閉
server.shutdown=graceful

# 設(shè)置緩沖期,最大等待時間,默認:30秒
spring.lifecycle.timeout-per-shutdown-phase=60s

此時,應(yīng)用在關(guān)閉時,Web 服務(wù)器將不再接受新請求,并等待正在進行的請求完成的緩沖時間。

然而,如果是 Spring Boot 2.3.0 之前,就需要自行擴展(線程池)來實現(xiàn)優(yōu)雅停機了。它的核心實現(xiàn)實現(xiàn)是在系統(tǒng)關(guān)閉時會調(diào)用 ShutdownHook,然后在 ShutdownHook 中阻塞 Web 容器的線程池,直到所有請求都處理完畢再關(guān)閉程序,這樣就實現(xiàn)自定義優(yōu)雅線下了。

但是,不同的 Web 容器(Tomcat、Jetty、Undertow)有不同的自定義優(yōu)雅停機的方法,以 Tomcat 為例,它的自定義優(yōu)雅停機實現(xiàn)如下。

2.1 Tomcat 容器關(guān)閉代碼

public class TomcatGracefulShutdown implements TomcatConnectorCustomizer, ApplicationListener<ContextClosedEvent> {
    private volatile Connector connector;

    public void customize(Connector connector) {
        this.connector = connector;
    }

    public void onApplicationEvent(ContextClosedEvent contextClosedEvent) {
        this.connector.pause();
        Executor executor = this.connector.getProtocolHandler().getExecutor();
        if (executor instanceof ThreadPoolExecutor) {
            try {
                log.info("Start to shutdown tomcat thread pool");
                ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) executor;
                threadPoolExecutor.shutdown();
                if (!threadPoolExecutor.awaitTermination(20, TimeUnit.SECONDS)) {
                    log.warn("Tomcat thread pool did not shutdown gracefully within 20 seconds. ");
                }
            } catch (InterruptedException e) {
                log.warn("Fail to shut down tomcat thread pool ", e);
            }
        }
    }
}

2.2 設(shè)置 Tomcat 自動裝配

@Configuration
@ConditionalOnClass({Servlet.class, Tomcat.class})
public static class TomcatConfiguration {
    @Bean
    public TomcatGracefulShutdown tomcatGracefulShutdown() {
        return new TomcatGracefulShutdown();
    }

    @Bean
    public EmbeddedServletContainerFactory tomcatEmbeddedServletContainerFactory(TomcatGracefulShutdown gracefulShutdown) {
        TomcatEmbeddedServletContainerFactory tomcatFactory = new TomcatEmbeddedServletContainerFactory();
        tomcatFactory.addConnectorCustomizers(gracefulShutdown);
        return tomcatFactory;
    }
}

PS:Jetty、Undertow 優(yōu)雅停機的實現(xiàn)方式,參考《面試訓(xùn)練營》,vx:gg_stone

課后思考

Spring Boot Actuator 能實現(xiàn)優(yōu)雅停機嗎?為什么?如何實現(xiàn)分布式系統(tǒng)的優(yōu)雅停機?

責(zé)任編輯:武曉燕 來源: Java中文社群
相關(guān)推薦

2025-03-17 00:00:00

2024-01-19 14:03:59

Redis緩存系統(tǒng)Spring

2023-01-30 07:41:43

2021-03-22 17:20:48

MYSQL開發(fā)數(shù)據(jù)庫

2015-08-13 10:29:12

面試面試官

2023-02-16 08:10:40

死鎖線程

2024-07-22 19:31:34

2021-07-06 07:08:18

管控數(shù)據(jù)數(shù)倉

2024-09-11 22:51:19

線程通訊Object

2010-08-12 16:28:35

面試官

2024-04-03 00:00:00

Redis集群代碼

2023-11-20 10:09:59

2024-02-20 14:10:55

系統(tǒng)緩存冗余

2022-05-23 08:43:02

BigIntJavaScript內(nèi)置對象

2010-08-27 10:53:14

面試

2024-02-28 10:14:47

Redis數(shù)據(jù)硬盤

2024-10-22 16:39:07

2023-09-01 15:27:31

2024-01-26 13:16:00

RabbitMQ延遲隊列docker

2024-04-09 10:40:04

點贊
收藏

51CTO技術(shù)棧公眾號