细说Springcloud eureka的几种主动下线服务的方式

2025-05-29 0 55

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

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

细说Springcloud eureka的几种主动下线服务的方式

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

细说Springcloud eureka的几种主动下线服务的方式

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

细说Springcloud eureka的几种主动下线服务的方式

1. 直接停掉服务。

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

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

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

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

细说Springcloud eureka的几种主动下线服务的方式

下图是用postman 发送delete请求

细说Springcloud eureka的几种主动下线服务的方式

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

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

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

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

discoverymanager.getinstance().shutdowncomponent();

例子如下,

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16
@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();

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:https://blog.csdn.net/sinat_25596967/article/details/80231669

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 细说Springcloud eureka的几种主动下线服务的方式 https://www.kuaiidc.com/110934.html

相关文章

发表评论
暂无评论