前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Boot(Cloud) 优雅停机

Spring Boot(Cloud) 优雅停机

作者头像
双鬼带单
发布2021-11-11 09:53:36
7550
发布2021-11-11 09:53:36
举报
文章被收录于专栏:CodingToDie

为了解决在微服务重启的过程中,可能出现一部分 http 请求处理失败的问题,提供一下方案

拟用方案:

第一步:重启前先从主动将服务剔除,并等待一段时间 第二步:停止服务并重启

一、主动将服务剔除

该方案主要考虑因为服务下线的瞬间,如果服务信息更新不及时,导致复杂均衡算法依然转发到已经停掉的实例上发生一些服务不可用的情况

在每个项目增加一个接口(例如 /discovery/deregister ),在项目重启的脚本中主动调用接口剔除这个服务,shell 大致改动如下:

代码语言:javascript
复制
function stop()
{    
    echo "deregister [${PROJECT}]."
    curl -X POST "127.0.0.1:${SERVER_PORT}/discovery/deregister"
    echo ""
    echo "deregister [${PROJECT}] then sleep 10 seconds."
    sleep 10
    kill xxxxxxxxxxxxxxxxxxxx
}

接口代码示例

代码语言:javascript
复制
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.serviceregistry.Registration;
import org.springframework.cloud.client.serviceregistry.ServiceRegistry;
import org.springframework.context.annotation.Lazy;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("discovery")
@Slf4j
public class DeregisterInstanceController {

  @Autowired
  @Lazy
  private ServiceRegistry serviceRegistry;

  @Autowired
  @Lazy
  private Registration registration;

  @PostMapping("deregister")
  public void deregister() {

    log.info("deregister serviceName:{}, ip:{}, port:{}",
        registration.getServiceId(),
        registration.getHost(),
        registration.getPort());
    try {
      serviceRegistry.deregister(registration);
    } catch (Exception e) {
      log.error("deregister error", e);
    }
  }
}

二、Spring Boot 自带的优雅停机方案

要求 Spring Boot 的版本大于等于 2.3

在配置文件中增加如下配置:

application.yaml

代码语言:javascript
复制
server:
    shutdown: graceful
spring:
    lifecycle:
        timeout-per-shutdown-phase: 10s

当使用 server.shutdown=graceful启用时,在 Web 容器关闭时,Web 服务器将不再接收新请求,并将等待活动请求完成的缓冲期。缓冲器默认是 30s, 具体项目时间根据具体情况而定

不同 web 容器优雅停机行为区别

容器停机行为取决于具体的 web 容器行为

web 容器名称

行为说明

tomcat 9.0.33+

停止接收请求,客户端新请求等待超时。

Reactor Netty

停止接收请求,客户端新请求等待超时。

Undertow

停止接收请求,客户端新请求直接返回 503。

两者一同使用效果更加

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-10-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 双鬼带单 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、主动将服务剔除
  • 二、Spring Boot 自带的优雅停机方案
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档