Eureka实现灰度发布(功能优雅下线)

背景:最近项目上线发布比较频繁,后台多台应用服务器分布式部署,采用springcloud进行微服务治理。 后台服务绝大多数注册到了Eureka上,系统是7*24小时需要保证活跃, 系统有多个工程,每个工程有多个restful服务,同时服务间的关联关系是网状式的。架构和业务流程不做详细赘述。

遇到的问题:Eureka上对应的服务工程进行上线发布时,为了保证前端客户请求无感知,同时保证服务端能够完整处理掉过程中的数据,实现真正的灰度发布。

项目使用了下述第三个方案,目前还未遇到问题,后续持续更新。 我们不是技术的开创者,只是技术的搬运工~

本文会介绍几种eureka 注册中心服务下线的方式

-----------------------------------------------------------------

补充:在启动eureka服务的时候发现控制台有以下的输出

由此猜想可以通过改接口下线服务, 于是尝试了一下

果然能从注册中心中移除该实例

---------------------------------------------------------------------

 

1. 直接停掉服务。

默认情况下,如果Eureka Server在90秒没有收到Eureka客户的续约,它会将实例从其注册表中删除。但这种做法的不好之处在于, 客户端已经停止了运行,但仍然在注册中心的列表中。 虽然通过一定的负载均衡策略或使用熔断器可以让服务正常进行,但有没有方法让注册中心马上知道服务已经下线呢? 

 

2.为了让注册中心马上知道服务要下线, 可以向eureka 注册中心发送delete 请求

格式为 /eureka/apps/{application.name}/

下面是下线一个hello-service的例子。 

下图是用postman 发送delete请求

 

值得注意的是,Eureka客户端每隔一段时间(默认30秒)会发送一次心跳到注册中心续约。如果通过这种方式下线了一个服务,而没有及时停掉的话,该服务很快又会回到服务列表中。

所以,可以先停掉服务,再发送请求将其从列表中移除。

3. 客户端主动通知注册中心下线 

如果你的eureka客户端是是一个spring boot应用,可以通过调用以下代码通知注册中心下线。 

DiscoveryManager.getInstance().shutdownComponent();

例子如下,

@RestController
public class HelloController {
    @Autowired
    private DiscoveryClient client;

    @RequestMapping(value = "/hello", method = RequestMethod.GET)
    public String index() {
        java.util.List<ServiceInstance> instances = client.getInstances("hello-service");       
        return "Hello World";
    }
    
    @RequestMapping(value = "/offline", method = RequestMethod.GET)
    public void offLine(){
    	DiscoveryManager.getInstance().shutdownComponent();
    }   
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值