优雅停机方案

article/2025/8/29 5:18:00

springboot优雅停机

  • 概述
  • 线上重启面临的问题
    • 常见问题
    • 解决方案思路
  • 优雅停机相关知识
    • Linux中断
    • ShutdownHook
    • SpringCloud对优雅停机的处理机制
      • SpringBoot ApplicationContext生命周期
      • Spring Bean生命周期
      • 服务注册生命周期
      • Ribbon自动重试
      • 服务发现的心跳检测
      • Ribbon负载均衡
    • tomcat的响应机制
    • Nginx的负载均衡策略
  • 传统架构的优雅停机方案
  • 微服务架构的优雅停机方案

概述

线上系统发布重启过程中保证业务的连续性,让服务的客户端无感知。实现这种目标的停机我们称之为优雅停机(Graceful Shutdown),这样的发布部署叫平滑发布(Gentle Deploment).

线上重启面临的问题

系统间调用模型
系统间调用模型

常见问题

  • 重启tomcat将导致处理中的请求丢失
  • 使用kill -15重启tomcat,如果服务一直没有成功关闭,将导致不断有新的请求进入并被挂起,最终失败.

解决方案思路

  1. 要做到应用容器停止不影响正在执行的业务.
  2. 负载均衡组件能自动感知服务节点下线和上线,新请求不再分发到旧服务.
  3. 对无法处理的请求尝试重试补偿.

优雅停机相关知识

Linux中断

在Linux/unix 下,中止一个Java进程有两种方式,一种是 kill -9 pid,一种是 kill -15 pill(默认)。

  • SIGNKILL(9) 的效果是立即杀死进程。 该信号不能被阻塞, 处理和忽略。
  • SIGNTERM(15) 的效果是正常退出进程,退出前可以被阻塞或回调处理。并且它是 Linux 缺省的程序中断信号。

ShutdownHook

JDK提供了Java.Runtime.addShutdownHook(Thread hook)方法,可以注册一个JVM关闭的钩子,它是一个回调函数.在一下几种场景中被调用:

  • 程序正常退出
  • 使用System.exit()
  • 终端使用Ctrl+C触发的中断
  • 系统关闭
  • OutOfMemory宕机
  • 使用Kill pid命令干掉进程

SpringCloud对优雅停机的处理机制

SpringBoot ApplicationContext生命周期

SpringBoot Application在启动时注册了ShutdownHook,在doClose()中声明了在ShutdownHook对DisposableBean进行关闭.
org.springframework.context.support.AbstractApplicationContext.registerShutdownHook()
org.springframework.context.support.AbstractApplicationContext.doClose()

Spring Bean生命周期

Spring框架中在bean初始化和销毁时候执行某个方法的三种实现方式。

  • 通过注解@PostConastruct 和 @PreDestroy来实现Bean初始化执行和销毁时候执行方法;
  • 通过实现接口InitializingBean ,DisposableBean来实现Bean初始化执行和销毁时候执行方法;
  • 通过xml配置文件中bean的init-method="" destroy-method=""来实现Bean初始化执行和销毁时候执行方法;

服务注册生命周期

ServiceRegistry声明了spring cloud对服务服务注册的生命周期.
通过AbstractAutoServiceRegistration.destroy()声明了Application关闭时的回调动作.
@PreDestroy
AbstractAutoServiceRegistration.destroy()

EurekaClientAutoConfiguration这个自动配置类做了相应的工作。

Ribbon自动重试

Ribbon针对以下异常自动重试(HttpClientLoadBalancerErrorHandler.retriable )

  • ConnectException.class,
  • SocketTimeoutException.class
  • ConnectTimeoutException.class,
  • NoHttpResponseException.class,
  • ConnectionPoolTimeoutException.class,
  • ConnectionClosedException.class,
  • HttpHostConnectException.class);

服务发现的心跳检测

ConsulCatalogWatch#catalogServicesWatch()声明了每隔一段时间会去注册中心检测服务状态,状态异常的服务节点将在负载均衡时排除掉.

Ribbon负载均衡

Ribbon的负载均衡体现在selectServer时.
在这里插入图片描述

tomcat的响应机制

  • tomcat的Connections和Thread不是直接对于的关系,当线程阻塞或者线程池关闭时,依然可以建立连接.
  • 当线程池正常,线程不够时,如果没有达到最大线程数,将不断新建线程.

Nginx的负载均衡策略

  • 当nginx发现upstream无法连接时,将不再分配请求到该节点
  • 如果可以建立连接,将基于负载均衡策略分发

传统架构的优雅停机方案

使用Nginx做tomcat的负载均衡,使用JDK自带的HttpURLConnection.

方案

  • 使用kill -15,等待30S,使用kill -9
  • 尽量保证所有请求在3S内处理完成
  • 接口调用方要设置超时参数,超时后对异常做处理
  • 接口调用方有选择的通过http重试或者整体任务重试实现完整性

微服务架构的优雅停机方案

使用Feign+Ribbon作为客户端和负载均衡.

方案

  • 使用kill -15,等待10S,使用kill -9
  • 尽量保证所有请求在1S内处理完成
  • 接口调用方要设置超时参数,超时后对异常做处理
  • 缩短服务发现健康检查间隔,建议配置在1S以内(默认1S).

参考资料

  1. 微服务部署与优雅停机
  2. 如何优雅关闭 Spring Boot 应用
  3. Spring Boot 2.0 之优雅停机
  4. nginx反向代理+负载均衡+服务器宕机解决办法

http://chatgpt.dhexx.cn/article/5cMZs07l.shtml

相关文章

多中间件优雅停机问题处理

事情是这样的,小明是一个工作五年的老程序员,半秃着的头已经彰显了他深不可测的技术实力。 这一天,小明收到了领导给过来的一个需求。 领导对小明说:“小明啊,你工作五年了,这个需求我交给你一个人负责很是…

图灵机停机问题的不可判定性

Turing Machine Halting Problem 停机问题:指判断任意一个程序是否能在有限的时间之内结束运行的问题。图灵机停机问题是不可判定的,意思即是不存在一个图灵机能够判定任意图灵机对于任意输入是否停机。 证明一: 参考链接:Turin…

服务优雅停机

优雅停机 ​ 什么是优雅停机 ​ 优雅停机指的是Java项目在停机时需要做好断后工作。如果直接使用kill -9 方式暴力的将项目停掉,可能会导致正常处理的请求、定时任务、RMI、注销注册中心等出现数据不一致问题。 ​ 如何解决优雅停机呢?大致需要解决如…

停机问题的理解

关于停机问题维基百科给出的定义是: 停机问题(halting problem)是逻辑数学中可计算性理论的一个问题。通俗的说,停机问题就是判断任意一个程序是否会在有限的时间之内结束运行的问题。该问题等价于如下的判定问题:给…

静态变量的使用

静态变量:即类中的静态变量 类变量被其他方法使用 不管是被自己类的方法使用,还是被其他类的方法使用 都可以直接使用,不需要实例化对象即可使用。通过类名调用。 (遵守访问修饰符) 类变量只能通过类方法初始化。 普通变量被其他方法使用 …

类变量/静态变量

类变量 引入类变量 案例引出类变量: 有几个小孩在玩游戏,不时会有其他的小孩加入一起玩。怎么统计一共有多少小孩在玩? 按照现有的知识,可以设计一个小孩类,定义一个加入的方法。然后在主程序类的main方法中&#xf…

变量、常量、静态变量、静态常量

1、变量 在JAVA中我们通过三个元素来描述变量:变量类型,变量名以及变量值。 String love“imooc”; 变量类型 变量名 值(其中String具有不可变性,重新赋值后会生成新的String对象,love变量名这实际是指向对象地址的引用…

类中静态变量

不能在类声明中 初始化静态变量,这是因为声明描述了如何分配内存,但并未实际分配内存。 对于静态类成员,无论这个类的对象有多少个,静态成员都只有一个 对于静态类成员,可以在类声明之外使用单独的语句来进行初始化。…

静态变量和实例变量的区别

静态变量和实例变量的区别 大家好,我是酷酷的韩~ 1.在语法定义上的区别: 静态变量前要加static关键字,而实例变量前则不加。 2.在程序运行时的区别: (1)实例变量属于某个对象的属性,必须创建了实例对象,其中的实例…

JAVA静态变量是什么

java静态变量是什么-Java基础-PHP中文网 在java中,静态变量指的是被static修饰的类的变量;静态变量被所有类实例对象所共享,在内存中只有一个副本,当且仅当在类初次加载时会被初始化。 本教程操作环境:windows7系统、j…

静态变量与动态变量

0.静态存储与动态存储 1)静态存储变量通常是在变量定义时就分定存储单元并一直保持不变,直至整个程序结束。静态变量,全局动态变量都是静态存储 2)动态存储变量是在程序执行过程中,使用它时才分配存储单元&#xff0…

C++之static,静态变量

目录 1.为什么要用静态变量 2.全局变量 3.静态局部变量 4.静态数据成员的空间开辟 5.静态数据成员 6.释放 7.总结 1.内存: 2.初始化: 3.最大的优点: 4.指针: 5.释放时机: 1.为什么要用静态变量 前面我们定义…

C++静态变量

静态变量(Static Variables)是在程序运行期间保持其存在和值的变量,不会随着函数的调用而销毁和重新创建。静态变量在内存中分配一次,并且在整个程序的生命周期中保持存在。 在 C 中,静态变量可以声明在函数内部、类内…

win10显示rpc服务器不可用,win10系统RpC服务器不可用的详细办法

win10系统使用久了,好多网友反馈说win10系统RpC服务器不可用的问题,非常不方便。有什么办法可以永久解决win10系统RpC服务器不可用的问题,面对win10系统RpC服务器不可用的图文步骤非常简单,只需要1、使用netsh interface ip add 添…

w7系统显示rpc服务器不可用,教你win7系统rpc服务器不可用怎么办

用户在使用电脑进行时间同步,安装打印机或者其它的操作的时候可能会遇到同样一个问题,那就是提示“RPC服务器不可用”,很多朋友可能对于RPC并不了解,更不知道如何解决,下面,小编就来跟大家讲解rpc服务器不可…

计算机无法登陆提示rpc服务器不可用,电脑rpc服务器不可用,教你电脑rpc服务器不可用怎么解决...

有网友表示进入磁盘管理对磁盘进行分区、更改盘符或压缩卷等操作的时候出现“RPC服务器不可用”的报错,rpc服务器不可用怎么办?很多朋友可能对于RPC并不了解,下面小编教你电脑rpc服务器不可用怎么解决吧。 rpc服务器不可用怎么办 打开“运行”窗口&…

rpc服务器不可用自动重启,rpc服务器不可用_详细解决方法,彻底修复

通过测试证明,“rpc服务器不可用”可能是由于中了冲击波和震荡波导致。 虽然这个是很老的病毒,但还是有小部分用户没有对系统没有进行升级导致出现“rpc服务不可用”情况。 电脑遭到冲击波可能会出现以下症状: 1、系统资源紧张,应用程序运行速度异常。 2、Word、Excel、Pow…

rpc服务器不可用桌面图标消失,rpc服务器不可用,教您rpc服务器不可用怎么办

有网友表示进入磁盘管理对磁盘进行分区、更改盘符或压缩卷等操作的时候出现“RPC服务器不可用”的报错,通常我们在安装打印机或者虚拟磁盘时,将出现此提示。下面,小编给大家介绍rpc服务器不可用的处理技巧。 用户在使用电脑进行时间同步&…

计算机无法登陆提示rpc服务器不可用,电脑提示RPC服务器不可用的解决方法

最近有Win7用户反映在使用打印机或使用电脑进行时间同步的时候,突然弹出“RPC服务器不可用”的提示,很多用户可能对于RPC并不了解,更不知道如何解决,现在小编就和大家分享Win7系统RPC服务器不可用的解决方法。 RPC服务器&#xff…

为什么我的电脑显示rpc服务器不可用,电脑提示RPC服务器不可用解决办法

电脑提示"RPC服务器不可用"解决办法 腾讯视频/爱奇艺/优酷/外卖 充值4折起 在使用电脑的过程中,有些小伙伴遇到了电脑提示“RPC服务器不可用”的情况。那么, 电脑提示“RPC服务器不可用”怎么办呢?下面,就和小编一起来看看吧。 原…