热门标签 | 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;


推荐阅读
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 装饰器是一种用于在不修改原函数代码的情况下,动态地添加功能的工具。它允许你在函数执行前后插入额外的逻辑,从而增强或改变函数的行为。 ... [详细]
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社区 版权所有