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

百度一面:SpringBoot如何優(yōu)雅停機(jī)?

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

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

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

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

1.SpringBoot如何實(shí)現(xiàn)優(yōu)雅停機(jī)?

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

  • 使用合理的 kill 命令,給 Spring Boot 項(xiàng)目發(fā)送優(yōu)雅停機(jī)指令。
  • 開(kāi)啟 Spring Boot 優(yōu)雅停機(jī)/自定義 Spring Boot 優(yōu)雅停機(jī)的實(shí)現(xiàn)。

2.合理殺死進(jìn)程

在 Linux 中 kill 殺死進(jìn)程的常用命令有以下這些:

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

因此,在以上命令中,我們不能使用“kill -9”來(lái)殺死進(jìn)程,使用“kill”殺死進(jìn)程即可。

3.設(shè)置SpringBoot優(yōu)雅停機(jī)

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

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

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

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

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

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

(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)設(shè)置 Tomcat 自動(dòng)裝配

@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;
    }
}
責(zé)任編輯:姜華 來(lái)源: 磊哥和Java
相關(guān)推薦

2023-09-04 00:00:07

百度長(zhǎng)連接網(wǎng)絡(luò)

2025-03-17 00:00:00

2024-03-18 14:06:00

停機(jī)Spring服務(wù)器

2023-01-30 07:41:43

2013-08-22 17:08:50

2014-07-25 17:12:39

數(shù)據(jù)庫(kù)WOT2014MongoDB

2011-10-21 09:28:25

百度地圖API

2024-11-01 12:45:28

2024-04-07 08:06:37

Spring事件應(yīng)用程序

2022-05-11 22:15:51

云計(jì)算云平臺(tái)

2024-06-19 08:02:33

2024-05-15 16:41:57

進(jìn)程IO文件

2021-05-08 08:33:00

Rocketmq日志數(shù)據(jù)源

2012-05-28 22:51:53

百度

2018-09-06 18:37:45

百度云

2024-08-08 09:05:54

2024-06-27 07:54:46

2024-11-11 16:40:04

2024-06-11 10:03:56

2022-05-10 22:00:41

UDPTCP協(xié)議
點(diǎn)贊
收藏

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