当前位置: 首页 > article >正文

Kubernetes探针实战:如何为Spring Boot应用配置存活、就绪与启动探针

1. 为什么Spring Boot应用需要Kubernetes探针在微服务架构中Spring Boot应用的健康状态直接影响整个系统的稳定性。想象一下这样的场景你的Java应用因为内存泄漏导致响应缓慢但JVM进程还在运行或者应用启动时需要加载大量数据导致前几分钟根本无法处理请求。这时候如果没有健康检查机制Kubernetes会认为这些僵尸服务是正常的继续把流量导给它们。我遇到过最典型的问题是一个Spring Cloud Gateway服务启动时需要加载200多个路由规则整个过程耗时近2分钟。如果没有配置启动探针Kubernetes在Pod启动30秒后就开始转发流量结果大量请求直接失败。后来我们通过组合使用三种探针完美解决了这个问题。2. 三种探针的核心区别与适用场景2.1 存活探针Liveness Probe就像它的名字一样存活探针负责检查容器是否活着。当检测失败时Kubernetes会无情地杀掉这个容器并重新创建一个。我通常用这个来处理以下问题应用死锁比如数据库连接池耗尽内存泄漏导致的OOM虽然JVM进程还在但已经无法正常工作线程池满导致的请求堆积livenessProbe: httpGet: path: /actuator/health/liveness port: 8080 initialDelaySeconds: 30 periodSeconds: 102.2 就绪探针Readiness Probe这个探针决定了Pod是否准备好接收流量。与存活探针不同它不会杀死容器只是暂时把Pod从Service的负载均衡池中摘除。我在这些场景一定会用它应用启动时的初始化阶段缓存预热、数据库连接建立等依赖服务不可用时的熔断状态流量激增时的自我保护模式readinessProbe: httpGet: path: /actuator/health/readiness port: 8080 initialDelaySeconds: 5 periodSeconds: 52.3 启动探针Startup Probe这是Kubernetes 1.16引入的新探针专门解决慢启动应用的问题。它的特殊之处在于启动期间会暂时禁用其他探针成功后就会永久退出不再检查特别适合Spring Boot应用初始化场景startupProbe: httpGet: path: /actuator/health/startup port: 8080 failureThreshold: 30 periodSeconds: 103. Spring Boot健康检查接口的实战配置3.1 使用Actuator暴露健康端点Spring Boot Actuator已经内置了健康检查功能只需要在pom.xml中添加dependency groupIdorg.springframework.boot/groupId artifactIdspring-boot-starter-actuator/artifactId /dependency然后在application.yml中配置management: endpoint: health: probes: enabled: true show-details: always endpoints: web: exposure: include: health3.2 自定义健康指标对于需要检查的特定组件可以继承AbstractHealthIndicatorComponent public class RedisHealthIndicator extends AbstractHealthIndicator { Override protected void doHealthCheck(Health.Builder builder) throws Exception { // 实现具体的健康检查逻辑 } }4. 生产环境最佳实践4.1 参数调优经验值根据我处理过的生产案例这些参数组合效果最好场景initialDelaySecondsperiodSecondsfailureThreshold常规服务30s10s3大数据量启动60s15s5关键核心服务10s5s14.2 必须避免的坑initialDelaySeconds设置过小曾经有个服务因为设置为5秒导致在GC暂停时被误杀检查接口性能问题有个健康检查接口执行了全表扫描直接把数据库拖垮未区分liveness和readiness把数据库连接检查放在liveness导致容器不断重启4.3 高级技巧分阶段配置对于特别复杂的应用我推荐使用分阶段配置startupProbe: httpGet: path: /actuator/health/startup port: 8080 failureThreshold: 30 periodSeconds: 10 readinessProbe: httpGet: path: /actuator/health/readiness port: 8080 initialDelaySeconds: 0 # 等startup成功后立即开始 periodSeconds: 5 livenessProbe: httpGet: path: /actuator/health/liveness port: 8080 initialDelaySeconds: 60 # 给足启动时间 periodSeconds: 105. 典型故障排查案例去年我们一个订单服务频繁重启查看事件日志发现Warning Unhealthy 3m kubelet Liveness probe failed: HTTP probe failed with statuscode: 503排查过程检查健康接口响应时间发现95线达到8秒发现健康检查里包含了对Redis集群的全节点检查其中一个Redis节点网络延迟高达2秒解决方案将Redis检查移到readiness探针liveness只检查应用基础状态调整后的配置livenessProbe: httpGet: path: /actuator/health/liveness port: 8080 periodSeconds: 10 readinessProbe: httpGet: path: /actuator/health/readiness port: 8080 initialDelaySeconds: 30这个案例让我深刻理解了不同探针的使用边界。现在团队有个规范所有Spring Boot服务必须配置三种探针且健康检查接口响应时间必须控制在1秒内。

相关文章:

Kubernetes探针实战:如何为Spring Boot应用配置存活、就绪与启动探针

1. 为什么Spring Boot应用需要Kubernetes探针 在微服务架构中,Spring Boot应用的健康状态直接影响整个系统的稳定性。想象一下这样的场景:你的Java应用因为内存泄漏导致响应缓慢,但JVM进程还在运行;或者应用启动时需要加载大量数据…...

Artix-7 FPGA的隐藏技能:用XC7A35T的GTP收发器实现5G原型验证(附Verilog代码)

Artix-7 FPGA的隐藏技能:用XC7A35T的GTP收发器实现5G原型验证 在通信算法开发领域,原型验证一直是项目推进的关键环节。传统方案往往需要昂贵的专用设备或高端FPGA平台,而Artix-7系列中的XC7A35T却提供了一个被低估的高性价比选择。这款定位…...

GD32 Timer触发ADC多通道DMA传输与PWM输出实战解析

1. GD32 Timer触发ADC多通道DMA传输的核心原理 在嵌入式系统中,高效的数据采集往往需要多个外设协同工作。GD32微控制器通过Timer定时触发ADC采样,再配合DMA传输数据,可以构建一个完全由硬件自动执行的采集流水线。这种设计最大的优势在于完全…...

Centos9远程连接优化:MobaXterm+SSH配置避坑指南

CentOS 9远程连接优化:MobaXtermSSH配置避坑指南 在服务器管理和云计算环境中,远程连接的稳定性和安全性始终是运维工作的核心痛点。CentOS 9作为企业级Linux发行版的最新迭代,其SSH服务默认配置往往无法满足高强度运维需求——连接超时、认…...

Passmark BurnInTest 30天试用指南:如何快速检测你的电脑稳定性(附详细报告解读)

Passmark BurnInTest 30天试用指南:从安装到报告解读的全流程实战 当你新组装了一台电脑,或是发现旧设备频繁蓝屏、死机时,如何快速判断硬件是否存在潜在问题?Passmark BurnInTest作为专业级的系统稳定性测试工具,能在…...

SMUDebugTool:解锁AMD Ryzen处理器潜能的专业调试工具

SMUDebugTool:解锁AMD Ryzen处理器潜能的专业调试工具 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://gi…...

罗技宏脚本场景化解决方案:从入门到精通的实战指南

罗技宏脚本场景化解决方案:从入门到精通的实战指南 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 宏脚本(可自动化执行系…...

Dify 2026缓存机制到底改了什么?——基于源码级diff(commit: d4f8a2c…)与OpenTelemetry链路追踪的逐行解读

第一章:Dify 2026缓存机制重构的背景与设计哲学Dify 2026 的缓存机制重构并非一次简单的性能优化,而是面向多租户、高并发、LLM推理链路动态化的系统性演进。随着应用从单模型服务扩展至混合模型编排、RAG 实时索引、工具调用上下文持久化等场景&#xf…...

南北阁Nanbeige 4.1-3B部署详解:Windows系统C盘空间清理与优化策略

南北阁Nanbeige 4.1-3B部署详解:Windows系统C盘空间清理与优化策略 你是不是也遇到过这种情况?兴致勃勃地想部署一个AI大模型玩玩,结果第一步就被“C盘空间不足”给拦住了。特别是像南北阁Nanbeige 4.1-3B这样的模型,本身就有几个…...

视频资源管理新范式:douyin-downloader的效率革命

视频资源管理新范式:douyin-downloader的效率革命 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 当你第3次在杂乱无章的"下载"文件夹中翻找上周保存的教学视频时,当你意识…...

抖音批量下载助手:高效内容采集与管理指南

抖音批量下载助手:高效内容采集与管理指南 【免费下载链接】douyinhelper 抖音批量下载助手 项目地址: https://gitcode.com/gh_mirrors/do/douyinhelper 核心价值解析 在信息快速迭代的数字时代,高效获取和管理网络内容成为内容创作者、研究者及…...

YOLOv5小目标检测实战:手把手教你集成SPD模块提升低分辨率图像识别效果

YOLOv5小目标检测实战:手把手教你集成SPD模块提升低分辨率图像识别效果 在无人机航拍、安防监控、卫星遥感等实际应用场景中,我们常常需要处理分辨率不高、目标物体极其微小的图像。作为一名长期奋战在一线的计算机视觉工程师,我深知在这些“…...

GD32F330C8T6实战:用旋转编码开关和M62429打造高性价比音量控制器(附完整代码)

GD32F330C8T6实战:高精度数字音量控制系统的设计与实现 在音频设备设计中,音量控制是一个看似简单却蕴含诸多技术细节的关键功能。传统机械电位器存在磨损、噪声和体积大等问题,而数字音量控制方案则能完美解决这些痛点。本文将详细介绍如何基…...

逻辑派FPGA实战:基于Verilog的RGB呼吸灯PWM控制详解

逻辑派FPGA实战:基于Verilog的RGB呼吸灯PWM控制详解 最近有不少朋友拿到逻辑派开发板后,想用它来做点炫酷的效果,比如让板载的RGB LED像呼吸一样缓缓明暗变化。这个“呼吸灯”效果听起来简单,但背后涉及的数字PWM(脉冲…...

春联生成模型-中文-base私有化部署:满足企业数据安全需求

春联生成模型-中文-base私有化部署:满足企业数据安全需求 每到年底,很多企业都会为准备新春物料而忙碌,其中春联、福字等传统元素是必不可少的。对于金融、政务这类机构来说,他们既想用上AI生成春联的便利,又对数据安…...

【MCP采样接口调用流深度解密】:20年架构师亲授Sampling链路5大关键节点与3类高频崩溃根因

第一章:MCP采样接口调用流全景概览MCP(Model Control Protocol)采样接口是模型服务中实现动态推理控制与数据采集的核心通道,其调用流贯穿客户端请求、网关路由、采样策略执行、模型前向计算及结果回传等关键环节。理解该流程的全…...

衡山派D21x平台SDMC驱动与文件系统参数配置详解

衡山派D21x平台SDMC驱动与文件系统参数配置详解 最近在衡山派D21x平台上做项目,要用到SD卡存储数据,发现很多朋友在配置SDMC驱动和挂载文件系统时容易卡住。今天我就把自己在实际项目中配置SD/MMC控制器(SDMC)的完整流程分享出来&…...

SPIRAN ART SUMMONER图像生成质量评估:专业评测方法与指标

SPIRAN ART SUMMONER图像生成质量评估:专业评测方法与指标 如何判断AI生成的图像质量好坏?本文为你揭秘专业级的评估体系 当我们用AI生成图像时,最常遇到的问题就是:"这张图到底算好还是不好?" 特别是使用SP…...

衡山派Luban-Lite系统LVGL示例程序配置与自定义APP开发实战

衡山派Luban-Lite系统LVGL示例程序配置与自定义APP开发实战 最近在用衡山派的开发板做项目,需要做一个带界面的产品。官方SDK里已经集成了LVGL这个强大的嵌入式图形库,还提供了几个现成的Demo。但很多朋友拿到手后,不知道该怎么配置这些Demo…...

Stable Yogi Leather-Dress-Collection部署教程:safetensors格式LoRA自动扫描与热加载实现原理

Stable Yogi Leather-Dress-Collection部署教程:safetensors格式LoRA自动扫描与热加载实现原理 1. 项目概述 Stable Yogi Leather-Dress-Collection是一款专为动漫风格皮衣穿搭生成设计的本地化工具,基于Stable Diffusion v1.5和Anything V5模型构建。…...

STM32F407最小可行硬件平台设计与实测验证

1. 项目概述本项目是一款基于STM32F407ZET6微控制器的高集成度核心板设计,面向嵌入式系统开发、教学实验及原型验证场景。与常规功能导向型核心板不同,该设计在保证完整硬件功能的前提下,融入了明确的工程美学表达——PCB正反面分别采用“纳西…...

Kimi和豆包提示词实战:5个让大模型秒变聪明的指令模板(附避坑指南)

Kimi和豆包提示词实战:5个让大模型秒变聪明的指令模板(附避坑指南) 当你对着AI助手输入问题,却得到一堆无关信息时,是否也想过"这AI怎么这么笨"?其实问题可能出在你的提问方式上。就像用老式收音…...

立创开源项目解析:基于ESP32-PICO-V3与PAJ7620U2的BlueGo隔空手势操控器设计与实现

手把手教你打造隔空手势操控器:基于ESP32与PAJ7620的BlueGo项目实战解析 最近在做一个智能家居的控制项目,想找一个能隔空操作、又足够便携的遥控设备,市面上成品要么功能单一,要么价格不菲。后来在立创开源平台发现了这个叫 Blue…...

从手动到自动:BetterNCM-Installer如何重塑网易云音乐插件部署体验

从手动到自动:BetterNCM-Installer如何重塑网易云音乐插件部署体验 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer 当你尝试为网易云音乐安装插件时,是否曾遭遇…...

春联生成模型中文版在网络安全领域的创新应用

春联生成模型中文版在网络安全领域的创新应用 春节贴春联是我们的传统习俗,红纸黑字,寄托着对新年的美好祝愿。但你有没有想过,当传统的春联遇上现代的网络安全,会碰撞出什么样的火花?今天,我们就来聊聊一…...

30分钟掌握Python二叉树:从原理到实战(附源码)

30分钟掌握Python二叉树:从原理到实战(附源码) 【免费下载链接】Python All Algorithms implemented in Python 项目地址: https://gitcode.com/GitHub_Trending/pyt/Python 二叉树是Python数据结构中的核心概念,掌握它能帮…...

国产MCU USB功率计设计:从采样到显示的嵌入式测量实践

1. 项目概述 这是一款基于国产32位MCU的嵌入式USB功率计,面向便携式电源监测场景设计。系统以国民技术N32G430系列微控制器为核心,集成高精度电流采样、电压测量、实时功率计算与本地可视化显示功能,可稳定工作于标准USB 5V供电路径中&#x…...

Qwen3-0.6B-FP8构建智能运维(AIOps)原型:日志异常模式识别

Qwen3-0.6B-FP8构建智能运维(AIOps)原型:日志异常模式识别 半夜被报警电话吵醒,登录服务器一看,CPU已经飙到90%,数据库连接池爆满,整个应用响应慢得像蜗牛。翻看日志,几千行信息里&…...

时间序列预测模型评估指标:从理论到实战的全面解析

1. 为什么时间序列预测需要专门的评估指标? 时间序列预测和普通回归问题最大的区别在于数据的顺序性。想象一下你在预测明天的天气——今天的温度会影响明天,而昨天的数据又会影响今天。这种前后依赖关系让时间序列预测变得独特,也使得评估指…...

Qwen3智能字幕系统Typora文档生成功能

Qwen3智能字幕系统Typora文档生成功能 1. 引言 写技术文档是每个开发者和内容创作者的日常任务,但传统的文档编写方式往往效率低下。想象一下这样的场景:你刚看完一段重要的技术视频,需要把其中的关键内容整理成文档。通常的做法是一边暂停…...