摘要: 微服务架构中的应用优雅停机主要是指应用实例有计划而平滑(即不产生需要处理的事故)的退出。 1 介绍
微服务架构中的应用优雅停机主要是指应用实例有计划而平滑(即不产生需要处理的事故)的退出。应用服务器的停机主要分为两类:主动停机和被动停机,而其中主动停机和大部分的被动停机都是可以实现优雅停机。如果应用不做优雅停机,则会带来以下情况:
- 数据丢失:内存的中数据尚未持久化至磁盘
- 文件损坏:正在操作写的文件因没有更新完成,导致文件损坏
- 请求丢失:排队中等待处理的请求丢失
- 响应丢失:成功的交易还没来得及做出响应
- 交易中断:正在处理至中间状态的交易被强制中断
- 服务未下线:上游服务依然还会继续往下游服务发送消费请求
而我们微服务的优雅升级的目标就是避免以上几种情况,从而避免人工干预的工作量和提升微服务架构的服务高可靠。
2 使用场景优雅停机可以解决以下场景:
- KILL PID
- 应用意外自动退出(System.exit(n))
- 使用脚本命令的方式停止应用
优雅停机解决不了以下场景:
- 突然断电
- 机器物理破坏
- KILL-9 PID或taskkill /f /pid
Java的优雅停机通常通过注册JDK的ShutdownHook(钩子)来实现,当系统接收到退出指令后,首先标记系统处于退出状态,不再接收新的消息,然后将积压的消息处理完,最后调用资源回收接口将资源销毁,最后各线程退出执行。简单的使用demo案例如下(简单版):
/**
* 优雅停机处理方式
*
* @author lry
**/
public class Main{
/**
* 启动应用
**/
public void start(){
// 第一步:启动应用服务……
// 第二步:注册JDK钩子
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
@Override
public void run() {
System.out.println("The hook running...");
//第三步:调用停机处理
stop();
}
}));
}
/**
* 停止应用
**/
public void stop(){
// 停止应用前停机处理(如:注销服务、标记不接受请求等)
}
}
登录后复制
超时控制
通常优雅退出需要有超时控制机制,如果到达超时时间仍然没有完成退出前的资源回收等操作,则由停机脚本直接调用KILL -9 PID的方式进行强制退出,不然可能会等待很长时间。
微服务的优雅停机没有统一的解决方案,只要抓住核心思想进行设计即可:
引流 → 挡板 → 等待停机
但在微服务架构中,我们可以遵守以下建议规则来设计微服务的优雅停机机制:
- 所有微服务应用都应该支持优雅停机
- 优先注销注册中心注册的服务实例
- 待停机的服务应用的接入点标记拒绝服务
- 上游服务支持故障转移因优雅停机而拒绝的服务
- 根据具体业务也提供适当的停机接口
微服务应用的优雅停机根据其使用者角色的不同,而主要分为两种类型:
-
- 微服务业务应用优雅停机设计:
-
- 微服务业务应用优雅停机设计
- 微服务网关应用优雅停机设计:
微服务网关应用优雅停机设计
其余各层设备的优雅停机都可从以上两种类型进行衍生出解决方案,如:
- 整个后端架构升级,则可从DNS或Nginx直接切换
- Nginx层升级,则可以从DNS直接切换
在业界开源的产品中,很多产品都使用了JDK钩子的方式来实现优雅停机,如以下产品:
- Netty
- DUBBO
以上就是微服务架构—优雅停机方案的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » 微服务架构—优雅停机方案
发表评论 取消回复