热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

深入研究下SpringBootActuator在kubernetes中探针的应用

文章目录背景健康监控SpringBootActuator使用kubernetes健康检查health源码分析Springboot版本更新支持kubernetes探针在springb

文章目录

    • 背景
    • 健康监控
    • Spring Boot Actuator
      • 使用
    • kubernetes 健康检查
    • health 源码分析
    • Spring boot 版本更新支持kubernetes 探针
    • 在spring boot 中使用kubernetes 探针
    • 总结


背景

不管什么样的场景,我们应用基本上都需要提供一个探针,判断应用是否存活,来监控应用是否存活,是否需要剔除服务,是否需要自动重启

健康监控

在不使用三方插件我们最简单的方式就是自己写个接口供外部调用去做类似心跳探测

@GetMapping("/health")public String health() {return ActionEnum.SUCCESS.name();}

Spring Boot Actuator

实际上Spring Boot Actuator已经给我们提供了相应的组件。

使用


spring boot 版本: 2.6.8


  1. 引入依赖

<dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starter-actuatorartifactId>dependency>

  1. 启动endpoint监控
    我们可以使用如下配置开启所有的接口(endpoint)监控

management:endpoints:web:exposure:include: &#39;*&#39;

也可以开启指定接口(endpoint)的监控

management:endpoints:web:exposure:exclude: health,beans,trace

默认的接口前缀都是/actuator开头&#xff0c;如果我们要自定义可以使用如下配置

management:endpoints:web:base-path: /manage

spring boot 为我们提供了如下可用的接口(endpoints)

路径描述
auditevents公开当前应用程序的审计事件信息。
beans显示应用程序中所有 Springbean 的完整列表
caches公开可用的缓存
conditions显示在配置和自动配置类上计算的条件以及它们匹配或不匹配的原因
configprops显示已排序的所有&#64;ConfigurationProperties 列表
env获取全部环境属性
flyway显示已经应用的任何 Flyway 数据库迁移。需要一个或多个 Flyway bean
health显示应用程序健康信息
httptrace显示 HTTP 跟踪信息(默认情况下是最后100次 HTTP 请求-响应)
info显示任意的应用程序信息
integrationgraph显示了 Spring integrationgraph。需要对 Spring-Integration-core 的依赖关系
threaddump获取线程活动的快照

更多请参考spring boot 官方文档


  1. 访问接口

添加了spring-boot-starter-actuator依赖并开启接口监控后&#xff0c;我们可以直接访问接口&#xff0c;比如health

我们访问:

http://localhost:8080/actuator/health

在这里插入图片描述
可以看到就返回了应用的健康信息,其他的接口就不一一演示了。因为这不是我们今天的重点

kubernetes 健康检查

当应用部署到kubernetes&#xff0c;kubernetes提供了两种探测机制

  • Liveness探测(存活探针)&#xff1a;Liveness探测让用户可以自定义判断容器是否健康的条件。如果探测失败&#xff0c;Kubernetes就会重启容器。
    在这里插入图片描述

  • Readiness探测(就绪探针)&#xff1a;Readiness探测则是告诉Kubernetes什么时候可以将容器加入到Service负载均衡池中&#xff0c;对外提供服务
    在这里插入图片描述

在2.3.0之前我们Liveness探测Readiness探测都可以使用health这个接口来处理。

health 源码分析

health的自动装配主要实现类是HealthEndpointAutoConfiguration

&#64;Configuration(proxyBeanMethods &#61; false)
&#64;ConditionalOnAvailableEndpoint(endpoint &#61; HealthEndpoint.class)
&#64;EnableConfigurationProperties(HealthEndpointProperties.class)
&#64;Import({ HealthEndpointConfiguration.class, ReactiveHealthEndpointConfiguration.class,HealthEndpointWebExtensionConfiguration.class, HealthEndpointReactiveWebExtensionConfiguration.class })
public class HealthEndpointAutoConfiguration {}

这里面我们可以一个比较核心的类HealthEndpointConfiguration
在这里插入图片描述
这里获取的就是health要检测的一些资源
在这里插入图片描述
比如数据库
在这里插入图片描述
这里就可以看到了一个问题&#xff0c;实际上容器的存活就绪探针是应该分开的。

  1. 存活的探测不应该依赖于数据库这些三方中间件
  2. 就绪就需要检测数据库连接池等三方中间件是否加载完成&#xff0c;是否可以提供服务了

Spring boot 版本更新支持kubernetes 探针

在这里插入图片描述
可以看到在spring boot 2.3后官方支持了kubernetes的这两种探针

在spring boot 中使用kubernetes 探针

默认只有应用在kubernetes容器中开会开启这两个探针即

  • /actuator/health/liveness
  • /actuator/health/readiness

如果我们本地需要开启测试可以添加如下配置开关

management:endpoint:health:probes:enabled: true

然后我们访问试试

在这里插入图片描述

可以看到是生效了

总结

我们从最初的健康探测&#xff0c;到kubernetes中的liveness(存活)探针readiness(就绪)探针
可见即使是最简单的健康检测也有这么多要研究的东西。
路漫漫其修远兮&#xff0c;吾将上下而求索啊&#xff01;


推荐阅读
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 在使用 MUI 框架进行应用开发时,开发者常常会遇到 mui.init() 和 mui.plusReady() 这两个方法。本文将详细解释它们的区别及其在不同开发环境下的应用。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
author-avatar
宛雨万青惠雯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有