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

SpringBoot Actuator健康检查:自定义HealthIndicator

在这里插入图片描述

文章目录

    • 引言
    • 一、Spring Boot Actuator健康检查概述
    • 二、自定义HealthIndicator的必要性
    • 三、实现自定义HealthIndicator
    • 四、高级健康检查配置
    • 五、实现自定义健康状态和响应码
    • 总结

引言

Spring Boot Actuator是Spring Boot框架中用于监控和管理应用程序的强大功能模块。它提供了多种端点(endpoints)来展示应用程序的各种运行时信息,如健康状态、指标、环境配置等。其中,健康检查(Health Check)是最常用的功能之一,可以实时监控应用程序及其依赖组件的健康状态。本文将详细介绍如何扩展Spring Boot Actuator的健康检查功能,通过自定义HealthIndicator来监控特定组件或服务的健康状态,从而提高系统的可观测性和可靠性。

一、Spring Boot Actuator健康检查概述

Spring Boot Actuator的健康检查功能通过/actuator/health端点暴露应用程序的健康状态信息。该功能基于组件化的设计,由多个HealthIndicator实现类组成,每个HealthIndicator负责检查一个特定组件或服务的健康状态。Spring Boot预置了多种HealthIndicator实现,如DiskSpaceHealthIndicator(检查磁盘空间)、DataSourceHealthIndicator(检查数据库连接)等。

应用程序的整体健康状态由所有HealthIndicator的状态汇总决定,遵循"最差状态优先"的原则。例如,如果任何一个组件状态为DOWN,则整体状态也为DOWN。这种设计使得我们能够快速定位问题所在。

// Spring Boot预置的HealthIndicator示例
@Component
public class DiskSpaceHealthIndicator implements HealthIndicator {private final FileStore fileStore;private final long threshold;// 构造函数注入依赖public DiskSpaceHealthIndicator(FileStore fileStore, @Value("${health.diskspace.threshold:10485760}") long threshold) {this.fileStore = fileStore;this.threshold = threshold;}@Overridepublic Health health() {long diskFreeInBytes;try {diskFreeInBytes = fileStore.getUnallocatedSpace();if (diskFreeInBytes >= threshold) {return Health.up().withDetail("total", fileStore.getTotalSpace()).withDetail("free", diskFreeInBytes).build();} else {return Health.down().withDetail("total", fileStore.getTotalSpace()).withDetail("free", diskFreeInBytes).withDetail("threshold", threshold).build();}} catch (IOException ex) {return Health.down().withException(ex).build();}}
}

二、自定义HealthIndicator的必要性

在实际生产环境中,应用程序往往依赖于多种外部服务和资源,如缓存服务、消息队列、第三方API等。Spring Boot预置的HealthIndicator可能无法覆盖所有这些组件。自定义HealthIndicator可以帮助我们监控这些特定组件的健康状态,及时发现潜在问题。

自定义HealthIndicator的应用场景包括:监控Redis缓存连接状态、检查消息队列可用性、验证第三方API响应时间、检查文件存储服务状态等。通过实现自定义HealthIndicator,我们可以将这些关键依赖的健康状态整合到Spring Boot Actuator的统一监控体系中。

// 自定义HealthIndicator的常见应用场景
@Component
public class RedisHealthIndicator implements HealthIndicator {private final StringRedisTemplate redisTemplate;public RedisHealthIndicator(StringRedisTemplate redisTemplate) {this.redisTemplate = redisTemplate;}@Overridepublic Health health() {try {// 执行简单的Redis操作来检查连接状态String result = redisTemplate.opsForValue().get("health:check");// 构建健康状态信息return Health.up().withDetail("testKey", "health:check").withDetail("testValue", result).withDetail("version", redisTemplate.getConnectionFactory().getConnection().info("server").get("redis_version")).build();} catch (Exception e) {return Health.down().withDetail("error", e.getMessage()).build();}}
}

三、实现自定义HealthIndicator

实现自定义HealthIndicator非常简单,只需创建一个实现HealthIndicator接口的类,并实现其health()方法。该方法返回一个Health对象,包含组件的状态(UP、DOWN等)以及相关的详细信息。Spring Boot会自动发现并注册所有HealthIndicator实现类。

HealthIndicator接口定义如下:

// HealthIndicator接口定义
public interface HealthIndicator {/*** 返回组件的健康状态* @return 健康状态信息*/Health health();
}

我们可以创建一个自定义的HealthIndicator来监控外部API服务的可用性:

@Component
public class ExternalApiHealthIndicator implements HealthIndicator {private final RestTemplate restTemplate;private final String apiUrl;public ExternalApiHealthIndicator(RestTemplate restTemplate, @Value("${external.api.url}") String apiUrl) {this.restTemplate = restTemplate;this.apiUrl = apiUrl;}@Overridepublic Health health() {long startTime = System.currentTimeMillis();try {// 发送请求检查API可用性ResponseEntity<String> response = restTemplate.getForEntity(apiUrl + "/health", String.class);long responseTime = System.currentTimeMillis() - startTime;// 判断响应状态if (response.getStatusCode().is2xxSuccessful()) {return Health.up().withDetail("status", response.getStatusCodeValue()).withDetail("responseTime", responseTime + "ms").withDetail("url", apiUrl).build();} else {return Health.down().withDetail("status", response.getStatusCodeValue()).withDetail("responseTime", responseTime + "ms").withDetail("url", apiUrl).build();}} catch (Exception e) {long responseTime = System.currentTimeMillis() - startTime;return Health.down().withDetail("error", e.getMessage()).withDetail("responseTime", responseTime + "ms").withDetail("url", apiUrl).build();}}
}

四、高级健康检查配置

除了基本的健康状态检查外,我们还可以通过Spring Boot提供的配置项来定制健康检查的行为,如设置健康检查的显示详细程度、配置特定HealthIndicator的启用状态等。

Spring Boot提供了三种级别的健康信息显示:

  • NEVER:不显示详细信息
  • WHEN_AUTHORIZED:仅向授权用户显示详细信息
  • ALWAYS:总是显示详细信息

这些配置可以在application.properties或application.yml中设置:

// 在application.yml中配置健康检查
management:endpoint:health:show-details: always  # 总是显示详细的健康信息endpoints:web:exposure:include: health,info  # 暴露health和info端点health:diskspace:enabled: true  # 启用磁盘空间健康检查db:enabled: true  # 启用数据库健康检查redis:enabled: true  # 启用Redis健康检查

对于更复杂的健康检查需求,我们可以实现CompositeHealthContributor接口,将多个相关的健康检查组合在一起:

@Component
public class MicroservicesHealthContributor implements CompositeHealthContributor {private final Map<String, HealthContributor> contributors = new HashMap<>();public MicroservicesHealthContributor(RestTemplate restTemplate,@Value("${service.user.url}") String userServiceUrl,@Value("${service.order.url}") String orderServiceUrl) {// 添加多个微服务的健康检查contributors.put("userService", new MicroserviceHealthIndicator(restTemplate, userServiceUrl));contributors.put("orderService", new MicroserviceHealthIndicator(restTemplate, orderServiceUrl));}@Overridepublic HealthContributor getContributor(String name) {return contributors.get(name);}@Overridepublic Iterator<NamedContributor<HealthContributor>> iterator() {return contributors.entrySet().stream().map(entry -> NamedContributor.of(entry.getKey(), entry.getValue())).iterator();}// 内部类:单个微服务的健康检查private static class MicroserviceHealthIndicator implements HealthIndicator {private final RestTemplate restTemplate;private final String serviceUrl;public MicroserviceHealthIndicator(RestTemplate restTemplate, String serviceUrl) {this.restTemplate = restTemplate;this.serviceUrl = serviceUrl;}@Overridepublic Health health() {try {ResponseEntity<Map<String, Object>> response = restTemplate.exchange(serviceUrl + "/actuator/health", HttpMethod.GET, null, new ParameterizedTypeReference<Map<String, Object>>() {});if (response.getStatusCode().is2xxSuccessful()) {Map<String, Object> body = response.getBody();String status = (String) body.get("status");if ("UP".equals(status)) {return Health.up().withDetails(body).build();} else {return Health.down().withDetails(body).build();}} else {return Health.down().withDetail("status", response.getStatusCodeValue()).withDetail("url", serviceUrl).build();}} catch (Exception e) {return Health.down().withDetail("error", e.getMessage()).withDetail("url", serviceUrl).build();}}}
}

五、实现自定义健康状态和响应码

Spring Boot默认定义了几种健康状态:UP、DOWN、OUT_OF_SERVICE和UNKNOWN。在某些场景下,我们可能需要定义更多的状态类型,如DEGRADED(性能下降)、MAINTENANCE(维护中)等。

我们可以通过扩展AbstractHealthIndicator类并设置自定义状态来实现:

@Component
public class CustomStatusHealthIndicator extends AbstractHealthIndicator {@Overrideprotected void doHealthCheck(Builder builder) throws Exception {// 检查逻辑boolean servicePartiallyAvailable = checkServicePartialAvailability();if (servicePartiallyAvailable) {// 使用自定义状态builder.status("DEGRADED").withDetail("reason", "Service is running with reduced capacity").withDetail("availableNodes", "2/5");} else {builder.up();}}private boolean checkServicePartialAvailability() {// 实际检查逻辑return true; // 示例返回值}
}

要使自定义状态生效,我们还需要配置HealthStatusHttpMapper来映射健康状态到HTTP响应码:

@Configuration
public class HealthConfiguration {@Beanpublic HealthStatusHttpMapper healthStatusHttpMapper() {Map<String, Integer> mapping = new HashMap<>();mapping.put("DOWN", HttpStatus.SERVICE_UNAVAILABLE.value());mapping.put("OUT_OF_SERVICE", HttpStatus.SERVICE_UNAVAILABLE.value());mapping.put("DEGRADED", HttpStatus.TOO_MANY_REQUESTS.value()); // 自定义状态映射return new HealthStatusHttpMapper(mapping);}
}

总结

Spring Boot Actuator的健康检查功能为我们提供了监控应用程序及其依赖组件健康状态的强大工具。通过实现自定义HealthIndicator,可以扩展这一功能,监控特定的组件或服务,提高系统的可观测性。本文介绍了自定义HealthIndicator的实现方法、高级配置选项以及自定义健康状态和响应码的实现方式。

在实际应用中,合理设计和实现健康检查机制可以帮助我们及时发现潜在问题,提高系统的可靠性和稳定性。健康检查不仅可以用于监控,还可以与容器编排系统(如Kubernetes)集成,实现自动故障检测和恢复。通过Spring Boot Actuator提供的健康检查功能,我们可以构建更健壮、更可靠的微服务系统,为用户提供更稳定的服务体验。在设计健康检查指标时,应当考虑真正反映系统健康状态的关键指标,避免引入过多不必要的检查项,以保证健康检查本身的性能和可靠性。

相关文章:

SpringBoot Actuator健康检查:自定义HealthIndicator

文章目录 引言一、Spring Boot Actuator健康检查概述二、自定义HealthIndicator的必要性三、实现自定义HealthIndicator四、高级健康检查配置五、实现自定义健康状态和响应码总结 引言 Spring Boot Actuator是Spring Boot框架中用于监控和管理应用程序的强大功能模块。它提供了…...

注意力机制(np计算示例)单头和多头

为了更好理解注意力机制里面的qkv矩阵&#xff0c;使用np来演示。 单头注意力 import numpy as np import math# 初始化输入 X X np.array([[[1, 2, 3], [4, 5, 6]]])# 初始化权重矩阵 WQ、WK、WV WQ np.array([[1, 0], [0, 1], [0, 0]])WK np.array([[1, 0], [0, 1], [0,…...

生成对抗网络(Generative adversarial network——GAN)

文章目录 1. 前言1.1 判别器和生成器的作用&#xff1f;2.2 个人总结 2. 核心代码示例2.1 训练判别器网络2.2 训练生成器网络 参考文章 1. 前言 生成对抗网络的原文&#xff1a;Generative Adversarial Nets&#xff0c;该论文的精读视频&#xff1a;生成对抗网络GAN开山之作论…...

CSGHub开源版本v1.6.0更新

CSGHub v1.6.0 带来了多项核心功能升级与性能优化&#xff0c;显著增强了对大模型推理、微调、评估等流程的支持&#xff0c;并进一步完善了推理服务与用户交互体验。 插件化推理与训练引擎框架 推理、微调和评估引擎现已全面模块化&#xff0c;支持通过配置文件灵活接入多种引…...

Redis日常学习(一)

我的Redis学习笔记&#xff1a;从命令行到性能调优 Redis Redis&#xff08;Remote Dictionary Server&#xff09;本质上是一个基于内存的键值存储系统. 安装配置Redis的过程非常简单&#xff1a; # Ubuntu/Debian安装Redis sudo apt-get update sudo apt-get install red…...

Unity3D仿星露谷物语开发37之浇水动画

1、目标 当点击水壶时&#xff0c;实现浇水的动画。同时有一个水从水壶中流出来的特效。 假如某个grid被浇过了&#xff0c;则不能再浇水了。。 如果某个grid没有被dug过&#xff0c;也不能被浇水。 2、优化Settings.cs脚本 增加如下内容&#xff1a; public static float…...

JavaScript 一维数组转不含零的两个数

问题描述&#xff1a; /*** param {number} n* return {number[]}*/ var getNoZeroIntegers function(n) {for(let i 1;i<n;i){if(String(i).indexOf(0) -1&&String(n-i).indexOf(0) -1){return [i,n-i]}}};String类型indexOf()函数如果找不到字串则返回-1&…...

抽象工厂模式及其在自动驾驶中的应用举例(c++代码实现)

模式定义 抽象工厂模式&#xff08;Abstract Factory Pattern&#xff09;是一种创建型设计模式&#xff0c;用于封装一组具有共同主题的独立对象创建过程。该模式通过提供统一接口创建相关对象家族&#xff0c;而无需指定具体实现类&#xff0c;特别适合需要保证系统组件兼容…...

知乎十四载:从精英问答到AI时代的知识灯塔

一、起源&#xff1a;Quora 的火种与周源的执念 2010 年&#xff0c;互联网浪潮正汹涌澎湃&#xff0c;各种新兴平台如雨后春笋般不断涌现。就在这一年的一个夜晚&#xff0c;周源像往常一样在网上浏览着各类信息&#xff0c;当他打开美国问答网站 Quora 时&#xff0c;瞬间被…...

Linux文件时间戳详解:Access、Modify、Change时间的区别与作用

在 Linux 系统中&#xff0c;文件的这三个时间戳&#xff08;Access、Modify、Change&#xff09;分别表示不同的文件状态变更时间&#xff0c;具体含义如下&#xff1a; 1. Access Time (Access) 含义&#xff1a;文件最后一次被访问的时间&#xff08;读取内容或执行&#xf…...

Doris + Iceberg 构建冷热分层数据湖架构:架构设计与实战指南

在海量数据治理与存储演进中&#xff0c;冷热数据分层 已成为降本增效的关键策略。本篇将深入探讨如何结合 Apache Doris 与 Apache Iceberg 构建一套高性能、可扩展的数据湖架构&#xff0c;支持冷热数据自动分层、快速查询与灵活扩展。 一、背景&#xff1a;为什么需要冷热数…...

顺序表和链表的区别(C语言)

前言 线性表是最基础的数据结构之一&#xff0c;其中顺序表与链表分别代表两种存储方式&#xff1a; 顺序表&#xff08;Sequential List&#xff09;&#xff1a;底层用数组实现&#xff0c;要求内存连续&#xff0c;典型代码以 int data[N] 或动态分配的 malloc/realloc 数…...

【Redis】Redis中的常见数据类型(一)

文章目录 前言一、Redis前置知识1. 全局命令2、数据结构和内部编码3. 单线程架构 二、String 字符串1. 常见命令2. 计数命令3.其他命令4. 内部编码5. 典型使用场景 三、Hash哈希1. 命令2.内部编码3. 使用场景4. 缓存方式对比 结语 前言 Redis 提供了 5 种数据结构&#xff0c;…...

Vue3 + TypeScript,使用祖先传后代模式重构父传子模式

父传子模式 父组件 SampleInput.vue <script setup lang"ts" name"SampleInput"> import { ref } from "vue"; import type { ApplyBasicInfo, Apply, ApplySample } from "/interface"; import CommonApplySampleTable from …...

MySQL:9.表的内连和外连

9.表的内连和外连 表的连接分为内连和外连 9.1 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选&#xff0c;之前查询都是内连 接&#xff0c;也是在开发过程中使用的最多的连接查询。 语法&#xff1a; select 字段 from 表1 inner join 表2 on 连接…...

(mac)Grafana监控系统之监控Linux的Redis

Grafana安装-CSDN博客 普罗米修斯Prometheus监控安装&#xff08;mac&#xff09;-CSDN博客 1.Redis_exporter安装 直接下载 wget https://github.com/oliver006/redis_exporter/releases/download/v1.0.3/redis_exporter-v1.0.3.linux-amd64.tar.gz 解压 tar -xvf redis_…...

Multisim使用教程详尽版--(2025最新版)

一、Multisim14前言 1.1、主流电路仿真软件 1. Multisim&#xff1a;NI开发的SPICE标准仿真工具&#xff0c;支持模拟/数字电路混合仿真&#xff0c;内置丰富的元件库和虚拟仪器&#xff08;示波器、频谱仪等&#xff09;&#xff0c;适合教学和竞赛设计。官网&#xff1a;艾…...

python pdf转图片再OCR

先pdf转图片 import os from pdf2image import convert_from_path# PDF文件路径 pdf_path /Users/xxx/2022.pdf # 输出图片的文件夹 output_folder ./output_images2022 # 输出图片的命名格式 output_name page# 如果输出文件夹不存在&#xff0c;创建它 if not os.path.ex…...

npm link 使用指南

npm link 使用指南 npm link 是一个非常有用的命令&#xff0c;主要用于在开发过程中将本地 npm 包链接到全局 npm 目录&#xff0c;从而可以在其他项目中使用这个本地包&#xff0c;而不需要发布到 npm 仓库。 基本用法 1. 创建全局链接 进入你要链接的本地包的根目录&…...

免费图片软件,可矫正倾斜、调整去底效果

软件介绍 有个超棒的软件要给大家介绍一下哦&#xff0c;它就是——ImgTool&#xff0c;能实现图片漂白去底的功能&#xff0c;而且重点是&#xff0c;它是完全免费使用的呢&#xff0c;功能超强大&#xff01; 软件特点及使用便捷性 这软件是绿色版本的哟&#xff0c;就像一…...

5G网络切片:精准分配资源,提升网络效率的关键技术

5G网络切片&#xff1a;精准分配资源&#xff0c;提升网络效率的关键技术 随着5G技术的广泛应用&#xff0c;网络切片&#xff08;Network Slicing&#xff09;作为其核心创新之一&#xff0c;正在改变传统网络架构。它通过将物理网络划分为多个逻辑网络&#xff08;切片&…...

seate TCC模式案例

场景描述 用户下单时&#xff0c;需要创建订单并从用户账户中扣除相应的余额。如果订单创建成功但余额划扣失败&#xff0c;则需要回滚订单创建操作。使用 Seata 的 TCC 模式来保证分布式事务的一致性。 1. 项目结构 假设我们有两个微服务&#xff1a; Order Service&#x…...

Transfomer的本质

Transformer是一个基于自注意力机制的深度学习模型&#xff0c;用于处理序列数据&#xff0c;主要结构包括编码器和解码器&#xff0c;每个部分由多头自注意力和前馈网络组成&#xff0c;加上残差连接和层归一化&#xff0c;以及位置编码。它解决了RNN的并行处理问题&#xff0…...

final修饰变量的注意

在Java中&#xff0c;使用final修饰变量时&#xff0c;需注意以下关键事项&#xff1a; 1. 初始化规则 实例变量&#xff1a; 必须在声明时、构造器或实例初始化块中初始化。所有构造器分支必须保证初始化。 class Example {final int x; // 实例变量final int y;public Exampl…...

前端与传统接口的桥梁:JSONP解决方案

1.JSONP原理 1.1.动态脚本注入 说明&#xff1a;通过创建 <script> 标签绕过浏览器同源策略 1.2.回调约定 说明&#xff1a;服务端返回 函数名(JSON数据) 格式的JS代码 1.3.自动执行 说明&#xff1a;浏览器加载脚本后立即触发前端预定义的回调函数&#xff08;现代开…...

SQL注入 01

0x01 用户、脚本、数据库之间的关系 首先客户端发出了ID36的请求&#xff0c;脚本引擎收到后将ID36的请求先代入脚本的sql查询语句Select * from A where id 36 &#xff0c; 然后将此代入到数据库中进行查询&#xff0c;查到后将返回查询到的所有记录给脚本引擎&#xff0c;接…...

Java之封装(学习笔记)

封装定义&#xff08;个人理解&#xff1a;&#xff09; 封装就像电视遥控器的按钮&#xff0c;比如音量键&#xff0c;对于我们使用者来说就是可以直接按下去调控音量&#xff0c;对于代码写作者来说就是封装了调控音量的方法&#xff0c;使得我们只能去调控&#xff0c;不能改…...

每天学一个 Linux 命令(27):head

​​可访问网站查看,视觉品味拉满: http://www.616vip.cn/27/index.html head 是 Linux 中用于查看文件开头部分内容的命令,默认显示文件前 10 行,适合快速预览文件结构或日志头部信息。 命令格式 head [选项] [文件]常用选项 选项说明-n <行数>指定显示前 N 行(如…...

山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改

在原代码中存在一个bug&#xff1a;当前对话的标题不是现有对话的用户的第一段的前几个字&#xff0c;而是历史对话的第一段的前几个字。 这是生成标题的逻辑出了错误&#xff1a; 当改成size()-1即可...

论文阅读:2024 ICML Is DPO Superior to PPO for LLM Alignment? A Comprehensive Study

Is DPO Superior to PPO for LLM Alignment? A Comprehensive Study https://www.doubao.com/chat/3506902534329346 https://arxiv.org/pdf/2404.10719 速览 这篇论文主要探讨了大语言模型对齐中两种主流方法——**DPO&#xff08;直接偏好优化&#xff09;和PPO&#xf…...

2025年人工智能指数报告:技术突破与社会变革的全景透视

《2025年人工智能指数报告》作为斯坦福大学人工智能实验室与多方合作的年度重磅研究&#xff0c;以超过千页的篇幅全景式展现了人工智能技术在全球范围内的发展轨迹与深远影响。这份报告不仅延续了对AI技术性能、科研进展与产业应用的追踪&#xff0c;更首次深入探讨了AI硬件的…...

【Python笔记 01】变量、标识符

一、 变量 1、变量的作用 计算机存储空间&#xff0c;用于保存数据。 2、定义变量的格式 格式&#xff1a;变量名 值 示例&#xff1a; num1 3 # num1就是一个变量&#xff0c;保存蛋糕的价格 num2 10 #num2也是一个变量&#xff0c;保存雪碧的价格 total num1 num2 …...

WebSocket启用备忘

一&#xff1a;引入依赖&#xff1a; <!--WebSocket专用--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency><dependency><groupId>org…...

文件管理详解(曼波脑图版)

(✪ω✪)曼波来啦&#xff01;文件管理的知识曼波这就为你详细讲解哟~ 记得要准备好小本本做笔记哦&#xff01;(๑˃̵ᴗ˂̵)و &#x1f31f; 文件读写操作 &#x1f31f; // 最可爱的文件读取写法 (✧∇✧) try (BufferedReader reader new BufferedReader(new FileRead…...

学习笔记十九——Rust多态

&#x1f9e9; Rust 多态终极通俗指南 &#x1f4da; 目录导航 多态一句话概念静态分派 vs 动态分派——根本差异参数化多态&#xff08;泛型&#xff09; 3.1 函数里的泛型 3.2 结构体里的泛型 3.3 方法里的泛型 3.4 枚举里的泛型Ad hoc 多态&#xff08;特例多态&#xff0…...

在 Linux 上部署 .NET Core 应用并配置为开机自动启动

在本文中&#xff0c;我们将详细介绍如何在 Linux 系统上部署 .NET Core 应用程序&#xff0c;并配置为开机自动启动。以下是一步一步的详细部署过程&#xff0c;适用于将 .NET Core Web 应用部署到生产环境中。 1. 安装 .NET 运行时和 SDK 首先&#xff0c;确保 Linux 系统上…...

dubbo SPI插件扩展点使用

参考&#xff1a;SPI插件扩展点 Dubbo SPI概述 使用IoC容器帮助管理组件的生命周期、依赖关系注入等是很多开发框架的常用设计&#xff0c;Dubbo中内置了一个轻量版本的IoC容器&#xff0c;用来管理框架内部的插件&#xff0c;实现包括插件实例化、生命周期、依赖关系自动注入…...

P8512 [Ynoi Easy Round 2021] TEST_152 Solution

Description 有一序列 c ( c 1 , c 2 , ⋯ , c m ) c(c_1,c_2,\cdots,c_m) c(c1​,c2​,⋯,cm​) 和 n n n 个三元组 ( l i , r i , v i ) (l_i,r_i,v_i) (li​,ri​,vi​). 回答 q q q 次形如 ( L , R ) (L,R) (L,R) 的询问&#xff0c;具体如下&#xff1a; 将 c c …...

开源项目FastAPI-MCP:一键API转换MCP服务

在当今AI开发的世界中,应用程序与AI模型之间的无缝集成至关重要。 模型上下文协议(Model Context Protocol, MCP)通过允许AI模型访问外部工具和数据源,弥合了这一差距。 FastAPI MCP是一个强大的工具,它可以通过最少的配置将您现有的FastAPI端点转换为MCP兼容的工具。 本…...

8、constexpr if、inline、类模版参数推导、lambda的this捕获---c++17

一、constexpr if&#xff1a;编译时条件分支 作用&#xff1a;在模板编程中&#xff0c;根据条件在编译时选择不同的代码路径&#xff0c;无需特化版本或复杂SFINAE技巧[替代SFINAE]。[SFINAE将在模版元编程再讲。下个月了。]基本语法 if constexpr (condition) {// 如果 co…...

github新建一个远程仓库并添加了README.md,本地git仓库无法push

1.本地git仓库与远程仓库绑定 2.push时报错&#xff0c;本地的 main 分支落后于远程仓库的 main 分支&#xff08;即远程有更新&#xff0c;但你本地没有&#xff09;&#xff0c;需要拉取远程的仓库--->在merge合并&#xff08;解决冲突&#xff09;--->push 3.但是git …...

贝叶斯分类器:原理、算法与应用详解

内容摘要 本文聚焦贝叶斯分类器&#xff0c;介绍其在各类分类器中分类错误概率最小的特性。详细阐述贝叶斯分类器的基本原理、朴素贝叶斯和半朴素贝叶斯分类器的算法&#xff0c;结合西瓜数据集实例说明朴素贝叶斯的应用。此外&#xff0c;还深入探讨极大似然估计和贝叶斯估计…...

算法篇之单调栈

单调栈算法入门 单调栈是一种特殊的数据结构应用&#xff0c;它的核心在于维护一个栈&#xff0c;使得栈内元素保持单调递增或者单调递减的顺序。这种数据结构在解决很多算法问题时非常有效&#xff0c;例如求数组中每个元素的下一个更大元素、每日温度问题等。 一、单调栈的…...

用python + PIL 实现图片格式转换工具

用python PIL 实现图片格式转换工具 要运行该程序&#xff0c;需要使用第三方库PIL&#xff08;pillow&#xff09;&#xff0c;详情可见https://blog.csdn.net/cnds123/article/details/126141838 格式支持&#xff1a; 支持常见图片格式转换&#xff08;JPEG, PNG, BMP, GIF…...

【数据库】事务

目录 1. 什么是事务&#xff1f; 2. 事务的ACID特性 3. 为什么使用事务&#xff1f; 4. 如何使用事务 4.1 查看支持事务的存储引擎 4.2 语法 4.3 保存点 4.4 自动/手动提交事务 5. 事物的隔离性和隔离级别 5.1 什么是隔离性 5.2 隔离级别 5.3 查看和设置隔离级别 1…...

C++:详解命名空间

目录 前言 一、命名空间是什么&#xff1f; 1.1命名空间域的定义 二、为什么有命名空间&#xff1f; 三、命名空间的用法 总结 前言 主要讲解命名空间是什么&#xff1f;为什么有命名空间&#xff1f;以及它的用法 一、命名空间是什么&#xff1f; 命名空间域&#xff08;nam…...

ClickHouse核心架构设计

列式存储原理与数据压缩 列式存储原理 列式存储 vs 行式存储 特性行式存储&#xff08;如MySQL&#xff09;列式存储&#xff08;ClickHouse&#xff09;数据排列按行连续存储&#xff08;所有字段相邻&#xff09;按列连续存储&#xff08;单列数据紧密排列&#xff09;适用场…...

K8s-Pod详解

Pod介绍 Pod是Kubernetes中能够创建和部署的最小单元&#xff0c;是Kubernetes集群中的一个应用实例&#xff0c;总是部署在同一个节点Node上。&#xff08;程序运行部署在容器中&#xff0c;容器必须存在pod中。pod可以认为是容器的封装&#xff0c;一个pod中可以存在一个或者…...

SSM(SpringMVC+spring+mybatis)整合的步骤以及相关依赖

目录 &#xff08;一&#xff09;导入SSM框架相关的依赖 ①创建一个新的web工程&#xff08;idea2023版&#xff09; ②思考三者之间的联系&#xff0c;回忆依赖 ③在pom.xml文件中引入依赖坐标 &#xff08;二&#xff09;使用注解开发&#xff0c;编写Spring的配置类&am…...

【LeetCode】算法详解#5 ---轮转数组

1.题目介绍 给定一个整数数组 nums&#xff0c;将数组中的元素向右轮转 k 个位置&#xff0c;其中 k 是非负数。 1 < nums.length < 105-231 < nums[i] < 231 - 10 < k < 105 2.解决思路 这道题的解决方法有很多&#xff0c;我这里给大家介绍我使用的方法。…...