Springcloud服务如何在Eureka安全优雅的下线
如果直接kill -9 Springcloud的服务,因为Eureka采用心跳的机制来上下线服务,会导致服务消费者调用此已经kill的服务提供者然后出错,处理这种情况有2中方案。
一、利用Spring Boot Actuato的管理端点(推荐)
1、pom中引用Actuato
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
2、properties中添加如下内容
#启用shutdown
endpoints.shutdown.enabled=true
#禁用密码验证
endpoints.shutdown.sensitive=false
如果只允许本机访问,可以添加如下属性
#(只允许本机访问服务,只能通过localhost、127.0.0.1、hostname访问服务,不能通过ip访问服务)
server.address=localhost
3、在任意一台服务器上利用curl发送shutdown命令
curl -X POST http://ip:8080/shutdown
或者
curl -d "" http://ip:8080/shutdown
二、利用Eureka的rest管理端点下线服务
eureka界面注册的服务:
发送DELETE的Restfull请求
注意:由于Springcloud服务是心跳检测,所有在eureka进行DELETE后要快速的停止服务,否则服务可能会被重新注册上。
优雅停止服务,当收到前面的指令后,服务会停止接受请求,如果服务正在处理请求,会等请求处理完成后在shutdown,验证通过。通过优雅停止服务来实现流量切换后进行灰度发布。