SpringCloud服务如何在Eureka安全优雅的下线
2024-10-19 02:24:59
如果直接KILL SpringCloud的服务,因为Eureka采用心跳的机制来上下线服务,会导致服务消费者调用此已经kill的服务提供者然后出错,处理这种情况有2中方案。
如需平滑的发布服务请参考:
springcloud如何实现服务的平滑发布
springcloud添加自定义的endpoint来实现平滑发布
一、利用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
# 禁用actuator管理端鉴权
management.security.enabled=false # 开启重启支持
endpoints.restart.enabled=true
如果只允许本机访问,可以添加如下属性
#(只允许本机访问)
server.address=localhost
3、在服务器上用curl发送post请求到pause.
curl -X POST http://localhost:/pause
此时eurake上该服务被标记问下线,但该服务其实还是可以正常访问的,当client还未及时更新本地Instances缓存时,依然不会中断服务。当所有client都感知到该服务DOWN后就不会再往该服务发请求了。
4、在服务器上利用curl发送shutdown命令
curl -X POST http://localhost:8080/shutdown 或者 curl -d "" http://localhost:8080/shutdown
二、利用Eureka的rest管理端点下线服务
eureka界面注册的服务:
发送DELETE的Restfull请求
对照关系看上面的2张图。
注意:由于cloud服务是心跳检测,所有在eureka进行DELETE后要快速的停止服务,否则服务可能会被重新注册上。
最新文章
- 将 instance 连接到 flat_net - 每天5分钟玩转 OpenStack(88)
- ENode框架Conference案例分析系列之 - Quick Start
- cf之路,1,Codeforces Round #345 (Div. 2)
- 十分钟搞懂什么是CGI
- 转:Java NIO系列教程(一)Java NIO 概述
- Linux多台服务器之间的文件共享
- 关于document.referrer的使用需要注意
- Oracle中使用escape关键字实现like匹配特殊字符,以及&字符的转义
- work3
- angular json转义html
- vs2010中的外部依赖项的含义
- 使用android的mediaplayer做成 一个demo,欢迎测试使用
- 存储可靠性技术之 --RAID
- python3 重写、重用、重载
- CKFinker 2.5.0.1 去demo标示
- Sql 标识列 增长1000
- 【带权并查集】【HDOJ】
- [右键]如何添加Sublime为右键菜单
- PHP在win7安装Phalcon框架
- 最小生成树 kuangbin专题最后一个题