SpringCloud(4) Eureka 如何主动下线服务节点

这篇具有很好参考价值的文章主要介绍了SpringCloud(4) Eureka 如何主动下线服务节点。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一共有三种从 Eureka 注册中心剔除服务的方式:

1.直接停掉客户端服务

执行如下命令,pid 表示客户端服务进程ID。

kill -9 pid

默认情况下,如果 Eureka Server90s 内没有收到 Eureka 客户端的续约,它会将实例从其注册表中删除。

这种做法的缺点在于,如果客户端已经停止了运行,但仍然在注册中心的列表中,那么当请求到已经停止运行的客户端时,就会发生错误。

2.发送HTTP请求

1)调用DELETE接口

为了让注册中心马上知道服务要下线,可以向 Eureka 注册中心发送 DELETE 请求,格式为:

  • 配置了用户名密码:
curl -s -X DELETE http://{username}:{password}@{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}
  • 没有配置用户名密码:
curl -s -X DELETE http://{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}

注意:

1.{instanceId} 是和客户端服务的 eureka.instance.instance-id 配置对应的,格式可能有所不同,取 UP (1) - 后面的内容就好。

2.{application} 大小写都可以。

举个例子:

我有一个 Eureka 注册中心和一个客户端服务(springboot-eureka-client):

  • Eureka注册中心:http://localhost:1001
  • 客户端服务(springboot-eureka-client):http://192.168.1.209:8081

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

如果我需要下线 springboot-eureka-client 服务,那么我可以请求如下地址:

curl -s -X DELETE "http://localhost:1001/eureka/apps/SPRINGBOOT-EUREKA-CLIENT/192.168.1.209:8081"

立即刷新页面,可以看到刚才注册的服务已经消失了。

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

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

2)调用状态变更接口

为了让注册中心马上知道服务要下线,可以向 Eureka 注册中心发送 PUT 请求,传递想要变更的参数。当参数值为 OUT_OF_SERVICE 的时候,服务就不会再使用这个节点了。请求格式为:

  • 配置了用户名密码:
curl -s -X PUT http://{username}:{password}@{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}/status?value=OUT_OF_SERVICE
  • 没有配置用户名密码:
curl -s -X PUT http://{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}/status?value=OUT_OF_SERVICE

相应的,如果想上线也可以用这个接口,将 value 值改为 UP 即可。

  • 配置了用户名密码:
curl -s -X PUT http://{username}:{password}@{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}/status?value=OUT_OF_SERVICE
  • 没有配置用户名密码:
curl -s -X PUT http://{eureka-ip}:{port}/eureka/apps/{application}/{instanceId}/status?value=OUT_OF_SERVICE
  • 查询服务列表:
curl -s http://{eureka-ip}:{port}/eureka/apps

补充:根据官方文档,服务的状态有 UPDOWNSTARTINGOUT_OF_SERVICEUNKNOWN 共五种状态,其他状态所代表的具体含义可以自行了解下。

官方文档: https://github.com/Netflix/eureka/wiki/Eureka-REST-operations

举个例子:

我有一个 Eureka 注册中心和一个客户端服务(springboot-eureka-client):

  • Eureka注册中心:http://localhost:1001
  • 客户端服务(springboot-eureka-client):http://192.168.1.209:8081

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

如果我需要下线 springboot-eureka-client 服务,那么我可以请求如下地址:

curl -s -X PUT "http://localhost:1001/eureka/apps/SPRINGBOOT-EUREKA-CLIENT/192.168.1.209:8081/status?value=OUT_OF_SERVICE"

请求之后,我们可以看到服务节点被标上了红色的 OUT_OF_SERVICE

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

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

1)代码示例

如果 Eureka 客户端是一个 Spring Boot 应用,可以通过调用一下代码通知注册中心下线。代码示例如下:

import com.demo.common.Result;
import com.netflix.discovery.DiscoveryManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

/**
 * <p> @Title RegisterController
 * <p> @Description 注册客户端Controller
 *
 * @author ACGkaka
 * @date 2023/7/12 22:16
 */
@RestController
@RequestMapping("/register")
public class RegisterController {

    @Autowired
    private DiscoveryClient discoveryClient;

    /** 获取服务实例信息 */
    @GetMapping("/getInstance")
    public Result<Object> getInstance() {
        List<ServiceInstance> instances = discoveryClient.getInstances("springboot-eureka-client");
        return Result.succeed().setData(instances);
    }

    /** 获取服务列表 */
    @GetMapping("/getServices")
    public Result<Object> getServices() {
        List<String> services = discoveryClient.getServices();
        return Result.succeed().setData(services);
    }

    /** 服务下线 */
    @GetMapping("/offline")
    public Result<Object> offline() {
        DiscoveryManager.getInstance().shutdownComponent();
        return Result.succeed();
    }
}
2)补充

补充:如果提示 Could not autowire. No beans of 'DiscoveryClient' type found.,如下图所示:

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

如果确保 Eureka Client 依赖已经正常导入,那么有可能是导入了错误的包:

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

3)测试

测试一: 获取服务实例信息,请求地址:http://localhost:8081/register/getInstance

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

测试二: 获取服务列表,请求地址:http://localhost:8081/register/getServices

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

测试三: 服务下线,请求地址:http://localhost:8081/register/offline

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

刷新 Eureka 页面,可以看到服务已经下线了。

SpringCloud(4) Eureka 如何主动下线服务节点,Spring Cloud,spring cloud,eureka,spring

整理完毕,完结撒花~ 🌻





参考地址:

1.细说Springcloudeureka的几种主动下线服务的方式,https://www.php1.cn/detail/XiShuo_Springclo_5a001b83.html

2.springCloud 之 Eureka 注册中心平滑下线客户端服务使用及原理,https://css.dandelioncloud.cn/article/details/1588695110810587137

3.eureka服务如何下线及启动,https://www.cnblogs.com/chenlifan/p/16191291.html文章来源地址https://www.toymoban.com/news/detail-572484.html

到了这里,关于SpringCloud(4) Eureka 如何主动下线服务节点的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • springcloud gateway实时监听nacos微服务上下线

    Nacos : 1.3.1 SpringCloud : 2021.0.2 SpringCloud gateway : 3.1.2 微服务下线后,网关存在短时间内转发失效服务,导致前端访问异常 微服务上线后,网关没有及时刷新本地缓存的服务,导致前端可能找不到服务实例 nacos的主动推送实例变化比网关自己拉取要及时的多 此处配置注意点: 1、

    2024年02月08日
    浏览(57)
  • SpringCloud使用nacos注册微服务,undertow为web服务器时,微服务下线问题

    服务下线时抛出异常: 出现错误原因:         由于服务下线时触发关闭Hook,undertow在nacos之前先关闭了,导致naocs取不到undertow里面的对象,导致空指针异常 处理方式:         1、这里导致服务无法下线,故可以重写这个 naocs 的 Hook         2、调整NacosWatch关闭顺序,在

    2024年02月11日
    浏览(43)
  • 【SpringCloud】Eureka原理分析、搭建Eureka服务、服务注册、服务发现

    🐌个人主页: 🐌 叶落闲庭 💨我的专栏:💨 c语言 数据结构 javaEE 操作系统 Redis 石可破也,而不可夺坚;丹可磨也,而不可夺赤。 当有两个服务,第一个服务需要远程调用第二个服务,采用的方式是发起一次HTTP请求,在之前的代码中是将服务提供者的ip和端口号硬编码到

    2024年02月07日
    浏览(49)
  • 【SpringCloud微服务--Eureka服务注册中心】

    gitee仓库 内容:SpringCloud + SpringCloud alibaba 技术栈:Java8+maven+git,github+Nginx+RabbitMQ+SpringBoot2.0 微服务架构是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。每个服务运行在其独立的 进程 中,服务与服务间采用

    2024年02月09日
    浏览(41)
  • SpringCloud:Eureka服务注册中心

    Eureka是一个服务治理组件,它主要包括服务注册和服务发现,主要用来搭建服务注册中心。 在搭建微服务项目时遇到的三个问题: 服务消费者该如何获取服务提供者的地址信息? 如果有多个服务提供者,消费者该如何选择? 消费者如何得知服务提供者的健康状态? Eureka的作

    2024年01月20日
    浏览(43)
  • SpringCloud之Eureka 服务注册中心

    5 Eureka 服务注册中心 5.1什么是 Eureka Netflix在涉及Eureka时,遵循的就是API原则. Eureka是Netflix的有个子模块,也是核心模块之一。Eureka是基于REST的服务,用于定位服务,以实现云端中间件层服务发现和故障转移,服务注册与发现对于微服务来说是非常重要的,有了服务注册与发

    2024年02月04日
    浏览(49)
  • springcloud Eureka服务注册与发现

    代码上传到 :https://github.com/13thm/study_springcloud/tree/main/days3 什么是服务治理 Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务治理 什么是服务注册与发现 Eureka采用了CS的设计架构,Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使

    2024年01月18日
    浏览(69)
  • Spring Cloud Gateway + Nacos 实现服务上下线无缝切换

    大家好,我是不才陈某~ 最近知识星球的球友在学习星球中的《精尽Spring Cloud Alibaba》专栏提到一个问题,相信也有很多人在线上环境遇到过,或许也因此被批过:一个集群中有某个服务突然下线,但是网关还是会去请求这个实例,所以线上就报错了,报错信息如下图: 究其

    2024年02月15日
    浏览(44)
  • Springcloud笔记(2)-Eureka服务注册中心

    Eureka作为一个微服务的治理中心,它是一个服务应用,可以接收其他服务的注册,也可以发现和治理服务实例。 服务治理中心是微服务(分布式)架构中最基础和最核心的功能组件,它主要对各个服务实例进行管理,包括 服务注册和服务发现 等 本文参考:springcloud教程 --

    2024年02月05日
    浏览(46)
  • SpringCloud搭建Eureka服务注册中心(六)

    前面说过eureka是c/s模式的  server服务端就是服务注册中心,其他的都是client客户端,服务端用来管理所有服务,客户端通过注册中心,来调用具体的服务; 我们先来搭建下服务端,也就是服务注册中心; project xmlns=\\\"http://maven.apache.org/POM/4.0.0\\\" xmlns:xsi=\\\"http://www.w3.org/2001/XMLSche

    2024年02月10日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包