细说Springcloud 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(); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
SpringBoot源码分析之bootstrap.properties文件加载的原理
本文通过访问看到bootstrap.properties中的信息获取到了,同时age也被application.properties中的属性覆盖掉了。加载顺序到底是什么?为什么会覆盖呢?我们接下来分析下吧2021-12-12Java ES(Elasticsearch) 中的and 和 or 查
Elasticsearch 是一个分布式、高扩展、高实时的搜索与数据分析引擎,es中match查询中,查询字符串分词后,默认是or或者的关系,这篇文章主要介绍了ES 中的and 和 or 查询,需要的朋友可以参考下2022-11-11
最新评论