【SpringBoot】SpringBoot优雅停机机制

news2024/12/26 19:51:37

文章目录

      • 背景
      • 1. 什么是优雅停机?
      • 2. Spring Boot 优雅停机的基础实现
        • 2.1立即停机模式
        • 2.2优雅停机模式
      • 3. 核心机制解析
        • 3.1. 启用 Shutdown Hook
        • 3.2. 自定义资源释放逻辑
        • 3.3. 超时机制
      • 4. 优雅停机的实际应用场景
        • 4.1. 服务更新
        • 4.2. 流量调控
        • 4.3. 订单处理
      • 5. 优雅停机可能失效的情况
      • 6. 实现无感知上下线
      • 总结

背景

想象一下,你正在乘坐一辆出租车,突然司机说:“车到一半我得下班了,您赶紧下车吧!”这样的经历肯定会让人感到非常糟糕。这不仅会导致用户体验极差,还可能让出租车平台的订单状态变得混乱——明明行程还在,却被迫中断,最终产生“脏数据”。

在微服务应用中,这种情况的对应场景便是应用程序的突然关闭。无论是因为维护需要还是意外问题,都可能导致用户请求中断,数据未能及时处理。为了解决这个问题,优雅停机机制成为现代系统中的重要一环。


1. 什么是优雅停机?

定义: 优雅停机是指在应用停止时,确保以下几点:

  • 拒绝新请求:关闭过程开始后,系统不再接收新的用户请求。
  • 完成当前请求:对已接收的请求完成处理,避免突然中断。
  • 资源清理:在停机前,释放各种资源(数据库连接、线程池等),保证系统的状态完整性。

目标: 优雅停机的核心是提供一种“无感知”的下线体验,让用户和系统都能安全退出。


2. Spring Boot 优雅停机的基础实现

Spring Boot 2.3 开始,优雅停机的支持更加简单和强大。通过设置 server.shutdown 配置,可以决定应用停机时的行为。

2.1立即停机模式

在立即停机模式下,应用会立刻中断所有请求和任务。

server:
  shutdown: immediate

虽然简单高效,但这种方式通常只适用于测试或无状态服务。

2.2优雅停机模式

在优雅停机模式下,Spring Boot 会等待当前的处理任务完成,再进行停机操作。

server:
  shutdown: graceful

注意: 该模式下的默认等待时间为 30 秒,可通过 spring.lifecycle.timeout-per-shutdown-phase 进行配置。


3. 核心机制解析

3.1. 启用 Shutdown Hook

Spring Boot 默认会通过 JVM 的 Shutdown Hook 触发优雅停机。确保以下配置启用:

spring:
  main:
    register-shutdown-hook: true
3.2. 自定义资源释放逻辑

如果需要在停机时执行特定的清理操作,比如关闭数据库连接或停止线程池,可以通过添加 Shutdown Hook 或实现 DisposableBean 接口。

示例代码:

@Component
public class GracefulShutdownTask implements DisposableBean {
    @Override
    public void destroy() throws Exception {
        System.out.println("关闭数据库连接...");
        System.out.println("释放线程池...");
        // 其他清理操作
    }
}

或者直接通过 JVM 钩子实现:

Runtime.getRuntime().addShutdownHook(new Thread(() -> {
    System.out.println("执行自定义的资源清理逻辑");
}));
3.3. 超时机制

避免因某些请求耗时过长导致系统停机过程被阻塞,可以通过以下配置设置超时时间:

spring:
  lifecycle:
    timeout-per-shutdown-phase: 20s # 默认30秒

4. 优雅停机的实际应用场景

4.1. 服务更新

在系统版本升级时,通过优雅停机完成请求处理和资源释放,避免对用户造成干扰。

4.2. 流量调控

在高并发场景下,如果需要暂时下线部分服务节点,优雅停机可以帮助实现“无感”迁移。

4.3. 订单处理

如出租车平台,在订单完成后再下线服务,避免出现“中途被抛弃”的情况。


5. 优雅停机可能失效的情况

  1. 强制关闭:使用 kill -9 强制终止进程将导致优雅停机机制无法触发。
  2. 资源耗尽:系统资源不足可能导致清理操作无法完成。
  3. 未配置超时:如果未配置超时时间,处理长时间任务可能导致停机时间过长。

6. 实现无感知上下线

在高可用系统中,优雅停机通常需要配合流量控制机制实现。例如:

  • Nginx服务网关:停机前先从负载均衡器中移除节点,停止分发新请求。
  • 健康检查:通过关闭健康检查响应,通知其他服务节点下线。

总结

优雅停机是一项提高用户体验和系统稳定性的关键机制。它通过拒绝新请求、完成当前任务、清理资源等方式,让应用的下线过程更安全、更友好。

通过 Spring Boot 提供的简单配置和扩展接口,我们可以轻松实现优雅停机,同时结合流量控制机制进一步优化用户体验。


推荐实践:

  1. 开发自定义的停机钩子,记录日志或上报指标,便于监控。
  2. 在服务升级流程中,优雅停机应作为标准操作。
  3. 配合负载均衡器进行无感上下线,进一步优化用户体验。

参考

【Spring Boot】【优雅停机一】Spring Boot 停机的正确方式 - 酷酷- - 博客园 (cnblogs.com)

【Spring Boot】【优雅停机二】Spring Boot 停机的正确方式 - 酷酷- - 博客园 (cnblogs.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2252948.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++ ——— 引用的概念以及特性

目录 引用的概念 引用在实际代码中的作用 引用的特性 1. 引用在定义时必须初始化 2. 一个变量可以有多个引用 3. 可以给别名再次取别名,或者多次取别名 4. 引用一旦引用了实体,就不能再引用其他实体了 引用的概念 引用不是新定义一个变量&#x…

Linux-异步IO和存储映射IO

异步IO 在 I/O 多路复用中,进程通过系统调用 select()或 poll()来主动查询文件描述符上是否可以执行 I/O 操作。而在异步 I/O 中,当文件描述符上可以执行 I/O 操作时,进程可以请求内核为自己发送一个信号。之后进程就可以执行任何其它的任务…

嵌入式入门Day23

数据结构Day4 操作受限的线性表栈基本概念顺序栈顺序栈结构创建顺序栈判空和判满栈扩容入栈出栈遍历销毁栈 链式栈队列基本概念顺序队列循环顺序队列定义循环队列的创建循环顺序队列的判空和判满循环顺序队列的入队循环顺序队列的遍历循环顺序队列的出队循环顺序队列的销毁 链式…

C语言实验 一维数组

时间:2024.12.3 一、实验 7-1 交换最小值和最大值 #include<stdio.h> int main() {int n, a[10], i, min = 0, max = 0;scanf("%d", &n);for (i = 0; i < n; i++){scanf("%d",&a[i]);}for (i = 0; i < n; i++){if (a[min] > a[i…

聚合支付系统官方个人免签系统三方支付系统稳定安全高并发

系统采用fastadmin框架独立全新开发&#xff0c;安全稳定,系统支持代理、商户、码商等业务逻辑。 针对最近一-些JD&#xff0c;TB等业务定制&#xff0c;子账号业务逻辑API 非常详细&#xff0c;方便内置对接! 注意&#xff1a;系统没有配置文档很使用教程&#xff0c;不清楚…

HTMLCSS 奇幻森林:小熊的甜蜜蛋糕派对大冒险

这个 HTML 页面包含了一个背景、多个下落的蛋糕图片和一个左右移动的loopy图片,实现了一个小熊吃蛋糕的效果 演示效果 HTML&CSS <!DOCTYPE html> <html><head><meta charset"utf-8" /><title>ideal life</title><style…

电脑关机的趣味小游戏——system函数、strcmp函数、goto语句的使用

文章目录 前言一. system函数1.1 system函数清理屏幕1.2 system函数暂停运行1.3 system函数电脑关机、重启 二、strcmp函数三、goto语句四、电脑关机小游戏4.1. 程序要求4.2. 游戏代码 总结 前言 今天我们写一点稍微有趣的代码&#xff0c;比如写一个小程序使电脑关机&#xf…

OpenSSL 自建CA 以及颁发证书(网站部署https双向认证)

前言 1、前面写过一篇 阿里云免费ssl证书申请与部署&#xff0c;大家可以去看下 一、openssl 安装说明 1、这部分就不再说了&#xff0c;我使用centos7.9&#xff0c;是自带 openssl的&#xff0c;window的话&#xff0c;要去下载安装 二、CA机构 CA机构&#xff0c;全称为…

在M3上面搭建一套lnmp环境

下载docker-desktop 官网下载docker-desktop 切换镜像源 {"builder": {"gc": {"defaultKeepStorage": "20GB","enabled": true}},"experimental": false,"registry-mirrors": ["https://docke…

WebSocket 通信说明与基于 ESP-IDF 的 WebSocket 使用

一、 WebSocket 出现的背景 最开始 客户端&#xff08;Client&#xff09; 和 服务器&#xff08;Server&#xff09; 通信使用的是 HTTP 协议&#xff0c;HTTP 协议有一个的缺陷为&#xff1a;通信只能由客户端&#xff08;Client&#xff09;发起。 在一些场景下&#xff0…

linux(centos) 环境部署,安装JDK,docker(mysql, redis,nginx,minio,nacos)

目录 1.安装JDK (非docker)1.1 将文件放在目录下&#xff1a; /usr/local/jdk1.2 解压至当前目录1.3 配置环境变量 2.安装docker2.1 验证centos内核2.2 安装软件工具包2.3 设置yum源2.4 查看仓库中所有docker版本&#xff0c;按需选择安装2.5 安装docker2.6 启动docker 并 开机…

CODESYS可视化秒表分批计时详细制作案例(一)

#制作一个在可视化界面可用于秒表计时的详细案例# 前言: 在电脑和手机的时钟上,都有一个秒表计时的功能。除此之外,在赛事上,也有更为专业的秒表计时器设备。举一反三,那么对于工控设备,为了衡量生产效率和节拍,引入了"Cycle Time(CT)"的概念,我们可以通…

openGauss开源数据库实战十八

文章目录 任务十八 openGauss逻辑结构:构:用户和权眼管理任务目标实施步骤一、准备工作二、用户和角色管理1.使用CREATE USER语句创建用户2.使用CREATE ROLE语句创建用户3.删除用户和角色 三、权限管理1.系统权限清理工作 任务十八 openGauss逻辑结构:构:用户和权眼管理 任务目…

Scratch游戏推荐 | 我的世界:平台冒险——像素世界的全新挑战! ⛏️

&#x1f3ae; Scratch游戏推荐 | 我的世界&#xff1a;平台冒险——像素世界的全新挑战&#xff01; ⛏️&#x1f30d; 今天给大家推荐一款精彩绝伦的Scratch平台冒险游戏——《我的世界&#xff1a;平台冒险 – 第二章》&#xff01;由atomicmagicnumber制作&#xff0c;这…

【java-数据结构篇】揭秘 Java LinkedList:链表数据结构的 Java 实现原理与核心概念

我的个人主页 我的专栏&#xff1a;Java-数据结构&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;点赞❤ 收藏❤ 目录 1. Java LinkedList 基础 1.1 LinkedList 简介 1.2 LinkedList 的实现原理 1.3 LinkedList 与 ArrayList 的区别 2. 链表基础 2.1 链…

北斗道路运输车辆管理应用:违规驾驶行为监测、车辆编队管理、安全跟踪(车辆历史轨迹查询)、车辆动态位置数据的实时查看和管理

文章目录 场景概述解决方案应用案例合作构想场景概述 面向旅游大巴车、危险品运输车及重型载货运输车等车辆,利用北斗定位导航服务,结合互联网通信技术,实现车辆安全驾驶管理与调度,有效降低道路事故发生风险,提升道路运输管理水平及车辆调度能力。 解决方案 在车辆上安…

【ABAP——DAILOG_2】

文章目录 使用Tabstrip控件实现分页签效果标签页的修改使用Table Control控件实现表单输出表格控件使用向导创建Table ControlTable Control列的修改 用户通过界面输入数据&#xff0c;数据通过屏幕控件传递到ABAP/4程序中的变量&#xff0c;程序在PBO中准备数据并显示界面&…

资料文件夹转移工具5.2.3 |快速转移到D盘,释放C盘空间

这是一款支持将C盘的常用文件夹转移到其他磁盘分区的工具&#xff0c;提供仅变目录、复制资料和转移资料三种转移方式。该工具完全免费&#xff0c;单文件免安装&#xff0c;大小仅为546KB&#xff0c;非常适合需要释放C盘空间的用户。 大小&#xff1a;546KB 下载地址&#…

使用STM32CubeMX配置串口各种功能

使用STM32CubeMX配置串口各种功能 STM32CubeMX软件的安装接收空闲中断STM32CubeMX配置1.新建工程2. 选择芯片3. 选择时钟和下载方式4. 配置串口5.设置工程消息6.生成代码7.修改生成的代码 空闲中断DMA转运STM32CubeMX配置4.配置串口5.设置工程消息6.生成代码7.修改生成的代码 S…

Javascript中DOM操作和事件监听综合练习 (具备三种功能的轮播图案例)

#如何去实现图片轮播效果图&#xff0c;通过创建一个基本的 HTML 页面结构&#xff0c;包含用于展示轮播图片的区域、左右切换箭头以及放置轮播图片的容器。# 整体架构 一、CSS 样式 接下来创建一个 styles.css 文件来设置页面的样式&#xff0c;让轮播效果看起来更美观。定义…