Spring Cloud使用了注冊中心(nacos)的服務(wù)優(yōu)雅下線方案

使用了注冊中心的服務(wù)集群净嘀,各個業(yè)務(wù)節(jié)點通過RestTemplate、openFeign進行內(nèi)部調(diào)用時,或者gateway做服務(wù)轉(zhuǎn)發(fā)時吮播,一般會使用從注冊中心獲取的服務(wù)節(jié)點列表進行負載路由,而當(dāng)一個服務(wù)節(jié)點被暴力關(guān)閉時眼俊,從注冊中心檢測到節(jié)點處在不健康狀態(tài)意狠,到注冊中心將該節(jié)點從維護列表中移除,再到其他業(yè)務(wù)節(jié)點將失效節(jié)點從自身維護的節(jié)點列表緩存數(shù)據(jù)中移除(定時拉取或廣播通知方式)疮胖,中間一般會經(jīng)歷數(shù)秒時長环戈,這時如果有轉(zhuǎn)向失效節(jié)點的新請求闷板,就會不得不等滿一個timeout周期,然后再反饋回調(diào)用端去做下一步是重試還是標(biāo)記熔斷的處理院塞≌谕恚總之,有異常發(fā)生拦止,不優(yōu)雅县遣。

(假裝有流程圖)

現(xiàn)成的有不少優(yōu)雅關(guān)閉服務(wù)的方案,比如使用actuator的shutdown端點汹族、提供入口調(diào)用SpringApplication的exit()靜態(tài)方法等艺玲,不過重要的是在做這些之前要能先主動的將節(jié)點從注冊中心中下線,然后等待一個合適的時間段之后再關(guān)閉服務(wù)鞠抑,這樣能多給正在處理中的請求執(zhí)行完成的機會饭聚。

下面是使用了nacos的服務(wù)下線示例代碼:


/** 使用了nacos注冊中心的服務(wù)關(guān)閉端點配置 */
@ConditionalOnClass(NacosAutoServiceRegistration.class)
@RestController
@RequestMapping("actuator")
@RequiredArgsConstructor
@Slf4j
public class NacosStopEndpoint {
    private final NacosAutoServiceRegistration nacosAutoServiceRegistration;
    private final ApplicationContext context;

    /** 注銷服務(wù)后關(guān)閉應(yīng)用前等待的時間(毫秒) */
    @Value("${stopService.waitTime:10000}")
    private int waitTime;

    /**
     * 關(guān)閉服務(wù) <br>
     * 只接收localhost發(fā)起的請求
     *
     * @param request
     * @return
     */
    @PostMapping("stopService")
    public ResponseEntity<Boolean> stopNacosService(
            HttpServletRequest request) {
        if (!request.getServerName().equalsIgnoreCase("localhost"))
            return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body(false);
        new Thread(
                        () -> {
                            log.info("Ready to stop service");
                            nacosAutoServiceRegistration.stop();
                            log.info("Nacos instance has been de-registered");
                            log.info("Waiting {} milliseconds...", waitTime);
                            try {
                                Thread.sleep(waitTime);
                            } catch (InterruptedException e) {
                                log.info("interrupted!", e);
                            }
                            log.info("Closing application...");
                            SpringApplication.exit(context);
                            ((ConfigurableApplicationContext) context).close();
                        })
                .start();

        return ResponseEntity.ok(true);
    }
}

這段代碼提供了一個 /actuator/stopService 的POST端點,調(diào)用它即可優(yōu)雅將服務(wù)下線搁拙,先把自身從nacos注冊中心中移除秒梳,等待10秒后關(guān)閉spring應(yīng)用。

接下來箕速,還需要找一個合適的時機來調(diào)用這個接口酪碘。如果使用了k8s,可以在容器生命周期中的prestop階段配置一個執(zhí)行腳本:

          lifecycle:
            preStop:
              exec:
                command:
                  - /bin/sh
                  - '-c'
                  - 'curl -X POST  ''http://localhost:8080/actuator/stopService'';\'
                  - sleep 30;

其中的sleep時間可以配置的比下線節(jié)點之后的等待時間稍長一些即可盐茎。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末兴垦,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子字柠,更是在濱河造成了極大的恐慌探越,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件窑业,死亡現(xiàn)場離奇詭異钦幔,居然都是意外死亡,警方通過查閱死者的電腦和手機常柄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門鲤氢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人西潘,你說我怎么就攤上這事卷玉。” “怎么了喷市?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵相种,是天一觀的道長。 經(jīng)常有香客問我东抹,道長蚂子,這世上最難降的妖魔是什么沃测? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任缭黔,我火速辦了婚禮食茎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘馏谨。我一直安慰自己别渔,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布惧互。 她就那樣靜靜地躺著哎媚,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喊儡。 梳的紋絲不亂的頭發(fā)上拨与,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機與錄音艾猜,去河邊找鬼买喧。 笑死,一個胖子當(dāng)著我的面吹牛匆赃,可吹牛的內(nèi)容都是我干的淤毛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼算柳,長吁一口氣:“原來是場噩夢啊……” “哼低淡!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起瞬项,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蔗蹋,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后囱淋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纸颜,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年绎橘,在試婚紗的時候發(fā)現(xiàn)自己被綠了胁孙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡称鳞,死狀恐怖涮较,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情冈止,我是刑警寧澤狂票,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站熙暴,受9級特大地震影響闺属,放射性物質(zhì)發(fā)生泄漏慌盯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一掂器、第九天 我趴在偏房一處隱蔽的房頂上張望亚皂。 院中可真熱鬧,春花似錦国瓮、人聲如沸灭必。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽禁漓。三九已至,卻和暖如春孵睬,著一層夾襖步出監(jiān)牢的瞬間播歼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工掰读, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留秘狞,地道東北人。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓磷支,卻偏偏與公主長得像谒撼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雾狈,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,055評論 2 355

推薦閱讀更多精彩內(nèi)容