当前位置: 代码网 > it编程>编程语言>Java > Eureka 的几种主动下线服务的方式

Eureka 的几种主动下线服务的方式

2024年08月02日 Java 我要评论
Eureka 的几种主动下线服务的方式

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

在这里插入图片描述
由此猜想可以通过改接口下线服务, 于是尝试了一下。
在这里插入图片描述
果然能从注册中心中移除该实例。
在这里插入图片描述

1. 直接停掉服务。

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

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

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

下面是下线一个hello-service的例子。
在这里插入图片描述

下图是用postman 发送delete请求:
![在这里插入图片描述](https://img-blog.csdnimg.cn/ef5d7013db28448081634bc00e490ec3.png

注:eureka客户端每隔一段时间(默认30秒)会发送一次心跳到注册中心续约。如果通过这种方式下线了一个服务,而没有及时停掉的话,该服务很快又会回到服务列表中。所以,可以先停掉服务,再发送请求将其从列表中移除。

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

可以通过发送curl http://servicename/offline 命令,或者postman方式调用客户端暴露服务下线的接口,实现客户端通知注册中心下线。

例如:

@restcontroller
public class servertestcontroller {

    @autowired
    private discoveryclient client;
 
    @getmapping(value = "/hello")
    public string index() {
        list<serviceinstance> instances = client.getinstances("hello-service");
        return jsonutils.tojsonstring(instances);
    }
    
    @getmapping(value = "/offline")
    public void offline(){
        discoverymanager.getinstance().shutdowncomponent();
    }   
}
(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com