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

Spring Boot 自动装配原理详解

        Spring Boot 的自动装配(Auto-Configuration)是其核心特性之一,它极大地简化了 Spring 应用的配置过程。通过自动装配,Spring Boot 能够根据项目中的依赖(例如,添加了 Spring Data JPA 依赖后自动配置数据库相关组件)动态配置所需的 Bean 和功能,而无需开发者手动编写繁琐的 XML 或 Java 配置。本文将从底层原理和源代码层面详细解析 Spring Boot 自动装配的实现机制,并以通俗易懂的语言和逐步推导的方式,让初学者也能清晰理解。


一、自动装配的核心思想

1. 什么是自动装配?

        自动装配是 Spring Boot 根据项目类路径(Classpath)中的依赖条件(Condition),自动为应用配置所需组件(Bean)的过程。例如:

  • 如果类路径中有 spring-boot-starter-web,Spring Boot 会自动配置一个内嵌的 Tomcat 服务器和 Spring MVC 组件。
  • 如果类路径中有 spring-boot-starter-data-jpa,Spring Boot 会自动配置数据源(DataSource)、EntityManagerFactory 等。

自动配置的组件种类

Spring Boot 提供的自动配置组件涵盖了开发中的常见场景,主要包括以下类别:

  1. Web 相关:嵌入式 Web 服务器(如 Tomcat)、Spring MVC、REST 服务等。
  2. 数据库相关:数据源(DataSource)、JPA、JDBC、NoSQL 数据库等。
  3. 消息队列:RabbitMQ、Kafka、JMS 等。
  4. 缓存:EhCache、Redis、Caffeine 等。
  5. 安全性:Spring Security、OAuth2 等。
  6. 监控与管理:Spring Actuator、健康检查、指标暴露等。
  7. 其他:邮件服务、任务调度、WebSocket 等。

        举例来说,自动装配就像一个“智能管家”:它会检查你的项目里有哪些“食材”(依赖),然后根据这些食材自动“烹饪”出需要的“菜品”(配置好的 Bean),而不需要你手动告诉它每一步怎么做。

2. 自动装配的核心问题

要实现自动装配,Spring Boot 需要解决以下问题:

  1. 如何知道要配置什么? —— 通过类路径中的依赖和预定义的自动配置类。
  2. 如何决定是否配置? —— 通过条件注解(如 @Conditional)判断是否满足配置条件。
  3. 如何加载和应用配置? —— 通过 Spring 的 SPI(Service Provider Interface)机制和 Spring 工厂机制。

二、自动装配的整体流程

以下是 Spring Boot 自动装配的完整步骤,后面会逐一详细推导每一步的原理和源代码实现。

  1. 启动 Spring Boot 应用:通过 @SpringBootApplication 注解触发自动装配。
  2. 加载自动配置类:通过 spring.factories 文件找到所有可能的自动配置类。
  3. 条件评估:根据条件注解(如 @ConditionalOnClass)决定哪些自动配置类生效。
  4. 创建 Bean:将生效的自动配置类中定义的 Bean 注册到 Spring 容器中。
  5. 用户自定义覆盖:允许用户通过配置文件或自定义 Bean 覆盖默认配置。

三、详细推导每一步的原理和源代码

步骤 1:启动 Spring Boot 应用

Spring Boot 应用的入口通常是一个带有 @SpringBootApplication 注解的主类,例如:

@SpringBootApplication
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
原理推导

@SpringBootApplication 是一个组合注解,展开后包含以下关键注解:

  • @SpringBootConfiguration:标记这是一个 Spring 配置类,相当于 @Configuration。
  • @EnableAutoConfiguration:启用自动装配,是自动装配的核心入口
  • @ComponentScan:扫描指定包下的组件(@Component、@Service 等具有相同功能的注解)。

重点是 @EnableAutoConfiguration,它通过 @Import(AutoConfigurationImportSelector.class) 引入了一个关键的类 AutoConfigurationImportSelector,这个类负责加载所有自动配置类。

通俗解释

  @EnableAutoConfiguration 就像一个“开关”,告诉 Spring Boot:“请根据我的项目环境,自动帮我配置好一切!” 而 AutoConfigurationImportSelector 是这个开关的“执行者”,它会去查找和加载所有可能的配置。

源代码分析

        AutoConfigurationImportSelector 的核心方法是 selectImports,它会返回需要导入的自动配置类的列表:

@Override
public String[] selectImports(AnnotationMetadata annotationMetadata) {if (!isEnabled(annotationMetadata)) {return NO_IMPORTS;}AutoConfigurationEntry autoConfigurationEntry = getAutoConfigurationEntry(annotationMetadata);return StringUtils.toStringArray(autoConfigurationEntry.getConfigurations());
}

这个方法会调用 getAutoConfigurationEntry 来加载自动配置类,接下来我们看它如何加载。


步骤 2:加载自动配置类

        Spring Boot 通过 spring.factories 文件来定义所有可能的自动配置类。这个文件通常位于依赖的 JAR 包中的 META-INF/spring.factories 路径下。

原理推导

  spring.factories 是一个键值对配置文件,格式如下:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration,\
org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration,\
...
  • 键是 org.springframework.boot.autoconfigure.EnableAutoConfiguration,表示自动配置类的入口。
  • 值是一个逗号分隔的类名列表,列出了所有可能的自动配置类。

        AutoConfigurationImportSelector 会通过 Spring 的 SpringFactoriesLoader 工具类读取 spring.factories 文件,获取所有自动配置类的全限定名

通俗解释

  spring.factories 就像一个“菜单”,列出了 Spring Boot 能提供的各种“菜品”(自动配置类)。AutoConfigurationImportSelector 会把这个菜单读出来,准备根据需要挑选合适的菜品。

源代码分析

  AutoConfigurationImportSelector 的 getAutoConfigurationEntry 方法会调用 SpringFactoriesLoader.loadFactoryNames 来加载配置:

protected AutoConfigurationEntry getAutoConfigurationEntry(AnnotationMetadata metadata) {if (!isEnabled(metadata)) {return EMPTY_ENTRY;}AnnotationAttributes attributes = getAttributes(metadata);List<String> configurations = getCandidateConfigurations(metadata, attributes);configurations = removeDuplicates(configurations);Set<String> exclusions = getExclusions(metadata, attributes);configurations.removeAll(exclusions);configurations = filter(configurations, autoConfigurationMetadata);fireAutoConfigurationImportEvents(configurations, exclusions);return new AutoConfigurationEntry(configurations, exclusions);
}protected List<String> getCandidateConfigurations(AnnotationMetadata metadata, AnnotationAttributes attributes) {List<String> configurations = SpringFactoriesLoader.loadFactoryNames(getSpringFactoriesLoaderFactoryClass(), getBeanClassLoader());Assert.notEmpty(configurations, "No auto configuration classes found in META-INF/spring.factories.");return configurations;
}

        SpringFactoriesLoader.loadFactoryNames 会扫描类路径下所有 JAR 包中的 META-INF/spring.factories 文件,提取 EnableAutoConfiguration 对应的类名列表。


步骤 3:条件评估

        加载了所有可能需要的自动配置类后,Spring Boot 需要决定哪些类真正生效。这通过条件注解(如 @ConditionalOnClass、@ConditionalOnMissingBean 等)实现。

原理推导

        每个自动配置类通常都会使用条件注解来指定其生效条件。例如,DataSourceAutoConfiguration 的代码可能如下:

@Configuration
@ConditionalOnClass({ DataSource.class, EmbeddedDatabaseType.class })
@ConditionalOnMissingBean(type = "io.r2dbc.spi.ConnectionFactory")
@EnableConfigurationProperties(DataSourceProperties.class)
@Import({ DataSourcePoolMetadataProvidersConfiguration.class, DataSourceInitializationConfiguration.class })
public class DataSourceAutoConfiguration {// 定义数据源相关的 Bean
}
  • @ConditionalOnClass:检查类路径中是否存在指定的类(如 DataSource.class)。
  • @ConditionalOnMissingBean:检查 Spring 容器中是否缺少某个 Bean。
  • @EnableConfigurationProperties:启用配置属性类(如 DataSourceProperties),从 application.properties 加载配置。

        Spring Boot 使用 ConditionEvaluator 类来评估这些条件注解,只有满足条件的自动配置类才会被加载。

通俗解释

        条件注解就像“筛选规则”。比如,@ConditionalOnClass(DataSource.class) 就像在说:“只有当厨房里有 DataSource 这个食材时,我才会做这道菜。” 如果条件不满足,这个自动配置类就会被跳过。

源代码分析

条件评估的核心逻辑在 ConditionEvaluator 类的 shouldSkip 方法中:

public boolean shouldSkip(AnnotatedTypeMetadata metadata, ConfigurationPhase phase) {if (metadata == null || !metadata.isAnnotated(Conditional.class.getName())) {return false;}// 获取 @Conditional 注解的条件AnnotationMetadata annotationMetadata = (AnnotationMetadata) metadata;for (String annotationType : annotationMetadata.getAnnotationTypes()) {if (annotationType.equals(Conditional.class.getName())) {// 评估每个条件// ...}}// 返回是否跳过
}

这个方法会检查自动配置类上的条件注解,调用每个条件的 matches 方法来判断是否满足。


步骤 4:创建 Bean

        对于通过条件评估的自动配置类,Spring Boot 会将其注册为 Spring 配置类,并执行其中定义的 @Bean 方法,创建相应的 Bean。

原理推导

自动配置类本质上是一个 @Configuration 类,里面定义了多个 @Bean 方法。例如:

@Configuration
public class DataSourceAutoConfiguration {@Bean@ConditionalOnMissingBeanpublic DataSource dataSource(DataSourceProperties properties) {// 创建并配置 DataSourcereturn createDataSource(properties);}
}

Spring 容器会调用这些 @Bean 方法,将返回的 Bean 注册到容器中,供应用使用。

通俗解释

        这一步就像“烹饪”:自动配置类提供了“菜谱”(@Bean 方法),Spring Boot 按照菜谱把“菜”(Bean)做好,放到“餐桌”(Spring 容器)上,供你的程序享用。

源代码分析

        Bean 的创建过程由 Spring 的 ConfigurationClassPostProcessor 处理,它会解析 @Configuration 类并注册 Bean 定义。核心逻辑在 ConfigurationClassParser 和 BeanFactory 中,这里不再展开(过于底层,涉及 Spring 核心)。


步骤 5:用户自定义覆盖

Spring Boot 允许用户通过以下方式覆盖默认的自动配置:

  1. 配置文件:在 application.properties 或 application.yml 中设置属性,例如:

    spring.datasource.url=jdbc:mysql://localhost:3306/mydb
    spring.datasource.username=root
    spring.datasource.password=123456
    

    这些属性会被 @EnableConfigurationProperties 加载到配置类中,影响 Bean 的行为。

  2. 自定义 Bean:用户可以定义自己的 Bean,覆盖自动配置的默认 Bean。例如:

    @Bean
    public DataSource myDataSource() {return new HikariDataSource(); // 自定义数据源
    }
    

    由于 @ConditionalOnMissingBean,如果用户定义了同类型的 Bean,自动配置的 Bean 就不会创建。

通俗解释

        这一步就像“点单”:Spring Boot 默认给你做了很多菜,但如果你说“我想要自己调个酱料”或者“我要换一道菜”,它会尊重你的选择,优先用你的配置。


四、自动装配的完整工作流程图

下面是自动装配的简化流程图:

1. 启动应用 (@SpringBootApplication)↓
2. 触发 @EnableAutoConfiguration↓
3. AutoConfigurationImportSelector 加载 spring.factories↓
4. 获取所有自动配置类列表↓
5. ConditionEvaluator 评估条件注解↓
6. 加载满足条件的自动配置类↓
7. 注册 Bean 到 Spring 容器↓
8. 用户配置覆盖默认配置

五、Spring Boot 自动配置的主要组件及其作用

以下列出了 Spring Boot 常见的自动配置组件及其作用。

1. Web 相关组件

  • 嵌入式 Web 服务器

    • 组件:Tomcat、Jetty、Undertow、Netty(用于 Reactive Web)。
    • 作用:提供一个内置的 Web 服务器,无需单独部署 WAR 文件到外部服务器。
    • 触发条件:类路径中存在 spring-boot-starter-web(默认包含 Tomcat)或 spring-boot-starter-webflux(默认包含 Netty)。
    • 示例:启动应用后,访问 http://localhost:8080 即可看到 Web 页面。
    • 配置文件:application.properties 中可设置 server.port=8081 更改端口。
  • Spring MVC

    • 组件:DispatcherServlet、视图解析器、异常处理器等。
    • 作用:支持基于 MVC 模式的 Web 开发,处理 HTTP 请求和响应。
    • 触发条件:类路径中存在 spring-webmvc。
    • 示例:定义一个 @RestController 即可处理 REST 请求。
  • WebFlux(响应式 Web)

    • 组件:WebClient、RouterFunction 等。
    • 作用:支持响应式编程,适合高并发场景。
    • 触发条件:类路径中存在 spring-boot-starter-webflux。

2. 数据库相关组件

  • 数据源(DataSource)

    • 组件:HikariCP(默认)、Tomcat JDBC、Commons DBCP2。
    • 作用:提供数据库连接池,管理数据库连接。
    • 触发条件:类路径中存在 JDBC 驱动(如 mysql-connector-java)和 spring-boot-starter-jdbc。
    • 配置文件:spring.datasource.url、spring.datasource.username 等。
  • Spring Data JPA

    • 组件:EntityManagerFactory、JpaTransactionManager。
    • 作用:简化数据库操作,支持 ORM(对象关系映射)。
    • 触发条件:类路径中存在 spring-boot-starter-data-jpa 和 Hibernate。
    • 示例:定义 @Entity 和 @Repository 即可操作数据库。
  • NoSQL 数据库

    • 组件:MongoDB、Redis、Cassandra 等客户端。
    • 作用:支持 NoSQL 数据库的连接和操作。
    • 触发条件:类路径中存在相关依赖(如 spring-boot-starter-data-mongodb)。

3. 消息队列

  • RabbitMQ

    • 组件:RabbitTemplate、AmqpAdmin。
    • 作用:支持消息发布和订阅。
    • 触发条件:类路径中存在 spring-boot-starter-amqp。
  • Kafka

    • 组件:KafkaTemplate、ConsumerFactory。
    • 作用:支持分布式流处理和高吞吐量消息队列。
    • 触发条件:类路径中存在 spring-kafka。

4. 缓存

  • 缓存支持
    • 组件:EhCache、Redis、Caffeine 等。
    • 作用:提高数据访问性能,减少数据库压力。
    • 触发条件:类路径中存在 spring-boot-starter-cache 和缓存实现(如 spring-boot-starter-data-redis)。
    • 示例:使用 @Cacheable 注解缓存方法结果。

5. 安全性

  • Spring Security

    • 组件:SecurityFilterChain、UserDetailsService。
    • 作用:提供认证和授权功能,保护应用安全。
    • 触发条件:类路径中存在 spring-boot-starter-security。
  • OAuth2

    • 组件:OAuth2 客户端、资源服务器。
    • 作用:支持单点登录和第三方认证。
    • 触发条件:类路径中存在 spring-security-oauth2-client。

6. 监控与管理

  • Spring Actuator
    • 组件:/actuator/health、/actuator/metrics 等端点。
    • 作用:提供应用监控、健康检查、指标收集。
    • 触发条件:类路径中存在 spring-boot-starter-actuator。

7. 其他组件

  • 邮件服务

    • 组件:JavaMailSender。
    • 作用:发送电子邮件。
    • 触发条件:类路径中存在 spring-boot-starter-mail。
  • 任务调度
    • 组件:TaskScheduler。
    • 作用:支持定时任务。
    • 触发条件:类路径中存在  spring-boot-starter  且启用 @EnableScheduling。
  • WebSocket
    • 组件:WebSocketHandler。
    • 作用:支持实时双向通信。
    •  触发条件:类路径中存在 spring-boot-starter-websocket。

六、常见问题解答

1. 为什么自动装配能减少配置?

        因为 Spring Boot 预定义了大量自动配置类,涵盖了常见场景(如 Web、数据库、消息队列等),并通过条件注解动态决定是否生效,省去了手动配置的麻烦。

2. 如何调试自动装配?

        Spring Boot 提供了 --debug 启动参数或设置 logging.level.org.springframework.boot=DEBUG,可以输出自动装配的详细日志,显示哪些配置生效、哪些被跳过。

3. 如何禁用某个自动配置?

        可以通过 @SpringBootApplication(exclude = {SomeAutoConfiguration.class}) 或在 application.properties 中设置:

spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration

七、总结

Spring Boot 的自动装配是一个高度模块化、智能化的配置机制,其核心依赖于以下组件:

  • @EnableAutoConfiguration 和 AutoConfigurationImportSelector:触发和加载自动配置。
  • spring.factories:定义所有可能的自动配置类。
  • 条件注解:动态决定配置是否生效。
  • Spring 容器:管理 Bean 的创建和注入。

        通过这些机制,Spring Boot 实现了“约定优于配置”的理念,让开发者只需关注业务逻辑,而无需关心底层配置的细节。希望本文的解释能让你对自动装配有更加清晰深入的理解!

相关文章:

Spring Boot 自动装配原理详解

Spring Boot 的自动装配&#xff08;Auto-Configuration&#xff09;是其核心特性之一&#xff0c;它极大地简化了 Spring 应用的配置过程。通过自动装配&#xff0c;Spring Boot 能够根据项目中的依赖&#xff08;例如&#xff0c;添加了 Spring Data JPA 依赖后自动配置数据库…...

Python核心数据类型全解析:字符串、列表、元组、字典与集合

导读&#xff1a; Python 是一门功能强大且灵活的编程语言&#xff0c;而其核心数据类型是构建高效程序的基础。本文深入剖析了 Python 的五大核心数据类型——字符串、列表、元组、字典和集合&#xff0c;结合实际应用场景与最佳实践&#xff0c;帮助读者全面掌握这些数据类型…...

索尼(sony)摄像机格式化后mp4的恢复方法

索尼(sony)的Alpha 7 Ⅳ系列绝对称的上是索尼的“全画幅标杆机型”&#xff0c;A7M4配备了3300万像素的CMOS&#xff0c;以及全新研发的全画幅背照式Exmor R™CMOS影像传感器&#xff0c;搭载BIONZ XR™影像处理器&#xff0c;与旗舰微单™Alpha 1如出一辙。下面我们来看看A7M4…...

Kubernetes容器运行时:Containerd vs Docker

Containerd 和 Docker 是容器技术领域的两个核心组件&#xff0c;它们在功能定位、架构设计、性能特点及适用场景上有显著差异。以下是两者的详细对比分析&#xff1a; 一、定位与功能 特性DockerContainerd核心定位完整的容器平台&#xff0c;包含构建、运行、编排等全生命周…...

免费专业级 PDF 处理!SolidPDF OCR 识别 + 精准转换批量处理

各位办公小能手们&#xff01;今天咱来聊聊一款超牛的软件——SolidConverterPDF。这可是个专业的多功能PDF处理工具&#xff0c;啥格式转换、文档编辑、扫描识别&#xff0c;它都能搞定&#xff01;下面我就给大伙详细唠唠它的厉害之处。 先说说它的核心功能。 一是PDF格式转换…...

电子电器架构 --- 区域计算架构(Zonal Compute)备战下一代电子电气架构

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…...

API的学习总结(上)

在 Java 中&#xff0c;API 指的是 Java 提供的一系列类、接口、方法和工具&#xff0c;用于开发 Java 应用程序。Java API 是 Java 平台的核心组成部分&#xff0c;它提供了丰富的功能&#xff0c;包括基础数据类型、集合框架、输入输出、网络编程、多线程、数据库连接等。 核…...

Spring Boot之Web服务器的启动流程分析

如何判断创建哪种web容器&#xff1a;servlet&#xff1f;reactive&#xff1f; 我们在启动Spring Boot程序的时候&#xff0c;会使用SpringApplication.run方法来启动&#xff0c;在启动流程中首先要判断的就是需要启动什么类型的服务器&#xff0c;是servlet&#xff1f;或者…...

代码随想录算法训练营第六十三天| 图论9—卡码网47. 参加科学大会,94. 城市间货物运输 I

每日被新算法方式轰炸的一天&#xff0c;今天是dijkstra&#xff08;堆优化版&#xff09;以及Bellman_ford &#xff0c;尝试理解中&#xff0c;属于是只能照着代码大概说一下在干嘛。 47. 参加科学大会 https://kamacoder.com/problempage.php?pid1047 dijkstra&#xff08…...

RAG之大规模解析 PDF 文档全流程实战

PDF 文档在商业、学术和政府领域无处不在,蕴含着大量宝贵信息。然而,从 PDF 中提取结构化数据却面临着独特的挑战,尤其是在处理数千甚至数百万个文档时。本指南探讨了大规模解析 PDF 的策略和工具。 PDF解析挑战 PDF 的设计初衷是为了提供一致的视觉呈现,而非数据提取。这…...

uart16550详细说明

一、介绍 uart16550 ip core异步串行通信IP连接高性能的微控制器总线AXI,并为异步串行通信提供了 控制接口。软核设计连接了axilite接口。 二、特性 1.axilite接口用于寄存器访问和数据传输 2.16650串口和16450串口的软件和硬件寄存器都是兼容的 3.默认的core配置参数&#xf…...

Docker 环境安装(2025最新版)

Docker在主流的操作系统和云平台上都可以使用&#xff0c;包括Linux操作 系统&#xff08;如Ubuntu、 Debian、Rocky、Redhat等&#xff09;、MacOS操作系统和 Windows操作系统&#xff0c;以及AWS等云平 台。 Docker官网&#xff1a; https://docs.docker.com/ 配置宿主机网…...

Comparator不满足自反性错误,Comparison method violates its general contract

APP运行退出&#xff0c;跟踪信息 java.lang.IllegalArgumentException: Comparison method violates its general contract! Collections.sort(idxsList);//按score升序排列 查看idxs类 public int compareTo(Idxs o) { //重写compareTo方法 return (int) (this.g…...

[Java实战]Spring Boot 3 整合 Apache Shiro(二十一)

[Java实战]Spring Boot 3 整合 Apache Shiro&#xff08;二十一&#xff09; 引言 在复杂的业务系统中&#xff0c;安全控制&#xff08;认证、授权、加密&#xff09;是核心需求。相比于 Spring Security 的重量级设计&#xff0c;Apache Shiro 凭借其简洁的 API 和灵活的扩…...

如何界定合法收集数据?

首席数据官高鹏律师团队 在当今数字化时代&#xff0c;数据的价值日益凸显&#xff0c;而合法收集数据成为了企业、机构以及各类组织必须严守的关键准则。作为律师&#xff0c;深入理解并准确界定合法收集数据的范畴&#xff0c;对于保障各方权益、维护法律秩序至关重要。 一…...

Flask+HTML+Jquery 文件上传下载

HTML 代码&#xff1a; <div id"loadingIndicator" style"display:none;"><div class"spinner"></div> </div> <!-- 请求过程中转圈圈 --> <form action"" method"post" enctype"m…...

MapReduce打包运行

&#xff08;一&#xff09;maven打包 MapReduce是一个分布式运算程序的编程框架&#xff0c;是用户开发“基于Hadoop的数据分析应用”的核心框架。 MapReduce核心功能是将用户编写的业务逻辑代码和自带默认组件整合成一个完整的分布式运算程序&#xff08;例如&#xff1a;jar…...

国产化Word处理控件Spire.Doc教程:如何使用 C# 从 Word 中提取图片

通过编程方式从 Word 文档中提取图片&#xff0c;可以用于自动化文档处理任务。E-iceblue旗下Spire系列产品是国产文档处理领域的优秀产品&#xff0c;支持国产化&#xff0c;帮助企业高效构建文档处理的应用程序。本文将演示如何使用 C# 和 Spire.Doc for .NET 库从 Word 文件…...

07 mysql之DQL

一、什么是DQL DQL 是 SQL 的一部分,专门用于查询数据。核心命令是 SELECT,是最常用的命令,支持: 简单查询条件过滤排序与分页多表连接聚合统计子查询与复杂逻辑二、基础查询语法 SELECT 字段1, 字段2, ... FROM 表名 WHERE 条件表达式 GROUP BY 分组字段 HAVING 分组条件…...

spark-standalone

一、定义&#xff1a;Standalone 模式是一种独立的集群部署模式&#xff0c;自带完整服务&#xff0c;可单独部署到一个集群中&#xff0c;无需依赖任何其他资源管理系统。 二、配置步骤 1.和前面一样拉到hadoop101的/opt/module这个目录里面。 2.压缩 3.重命名为spark-sta…...

运行Spark程序-在shell中运行 --SparkConf 和 SparkContext

SparkConf 类用于配置 Spark 应用程序的各种参数。通过 SparkConf 类&#xff0c;你可以设置应用程序的名称、运行模式&#xff08;如本地模式、集群模式&#xff09;、资源分配&#xff08;如内存、CPU 核心数&#xff09;等。主要作用配置应用程序参数&#xff1a;可以设置 S…...

分割任务 - 数据增强

语义分割 - FCN &#xff1a; 数据预处理/数据增强 算法源码实例 base_size520 crop_size480 flip_prob0.5if train_val train:self.transforms transforms.Compose([transforms.RandomResize(int(base_size*0.5), int(base_size*2)),transforms.RandomHorizontalFlip(flip_…...

基于C#+MySQL实现(WinForm)企业设备使用信息管理系统

企业设备使用信息管理系统 引言 企业的设备管理在企业的生产制造和管理过程之中意义比较重大&#xff0c;明确企业的设备的产权和维护成本对于企业的成本控制和财务管理之中起到了重要的作用。随着市场竞争的加剧&#xff0c;现代企业所处的市场环境发生了深刻的变革&#xf…...

JavaScript异步编程 Async/Await 使用详解:从原理到最佳实践

&#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Micro麦可乐的博客 &#x1f425;《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程&#xff0c;入门到实战 &#x1f33a;《RabbitMQ》…...

Babylon.js学习之路《四、Babylon.js 中的相机(Camera)与视角控制》

文章目录 1. 引言&#xff1a;为什么相机是 3D 场景的“眼睛”&#xff1f;1.1 相机的核心作用1.2 常见相机类型概览 2. 相机基础参数解析2.1 通用属性2.2 相机坐标系 3. 详解常用相机类型3.1 自由相机&#xff08;FreeCamera&#xff09;3.2 弧形旋转相机&#xff08;ArcRotat…...

MCP Server多节点滚动升级一致性治理

飞书云文档原链接地址&#xff1a;https://ik3te1knhq.feishu.cn/wiki/W8ctwG2sAiPkrXkpl7ocP0g0njf [!TIP] MCP Server 多节点部署时&#xff0c;滚动发布&#xff0c;MCP Client 侧使用的 Client 连接保证使用的是最新的工具配置信息 后续推进&#xff1a;按比例使用旧、新实…...

多线程(二)

今天先来了解一个上一期的遗留概念 —— 前台线程与后台线程 一 . 前台线程与后台线程 大家应该多多少少都听过酒桌文化&#xff0c;咱们平常吃饭&#xff0c;座位次序是没有那么多讲究的&#xff0c;但是在跟领导吃饭&#xff0c;或者出席宴会和一些重要场所的饭局时&#…...

2025年,大模型LLM还有哪些可研究的方向?

近两年LLM在学术界与工业界的发展大家都有目共睹。到了今年&#xff0c;以预训练LLM为代表的大模型PK上半场已然结束&#xff0c;接下来就要进入下半场大模型2.0时代了。 那么在这新赛道&#xff0c;关于大模型我们还有什么可做的创新&#xff1f;要知道&#xff0c;如今的大模…...

VS打断点调试,无法命中断点或断点失效,解决方法

1.打开需要打断点的模块&#xff0c;点击属性&#xff0c;将C/C常规的调试信息格式改为程序数据库&#xff08;/Zi&#xff09; 2.将C/C的优化禁用&#xff08;/Od&#xff09; 3.将链接器中的生成调试信息改为生成调试信息&#xff08;/DEBUG&#xff09; 注&#xff1a;如果需…...

ELF文件详解

ELF 文件不仅仅是一个格式&#xff0c;它是 Linux 世界中程序的"灵魂容器"&#xff0c;承载着程序从编译到执行的整个生命周期。 今天咱们来聊一个看起来高深&#xff0c;实际上理解起来其实挺简单的话题—— ELF 文件。 不知道你有没有想过&#xff1a;我们敲下./…...

【学习笔记】Shell编程---流程控制语句

最近学了好多个流程控制语句&#xff0c;都有点混乱了&#xff0c;赶紧先把各种用法记录下来&#xff01; if 语句 语法格式&#xff1a; if 条件测试命令串 then 条件为真时执行的命令 else 条件为假时执行的命令 fi 以关键字if开头&#xff0c;后跟条件测试表达式&…...

TensorFlow 常见使用场景及开源项目实例

TensorFlow 常见使用场景及开源项目实例 摘要 本文详细介绍了 TensorFlow 在多个领域的典型应用及其对应的开源项目案例。涵盖了图像处理、自然语言处理、语音音频处理、推荐系统与时间序列预测、移动端与边缘计算以及生成式模型与创意应用等多方面内容&#xff0c;列举了大量…...

王炸组合!STL-VMD二次分解 + Informer-LSTM 并行预测模型

往期精彩内容&#xff1a; 单步预测-风速预测模型代码全家桶-CSDN博客 半天入门&#xff01;锂电池剩余寿命预测&#xff08;Python&#xff09;-CSDN博客 超强预测模型&#xff1a;二次分解-组合预测-CSDN博客 VMD CEEMDAN 二次分解&#xff0c;BiLSTM-Attention预测模型…...

OpenCV进阶操作:风格迁移以及DNN模块解析

文章目录 前言一、风格迁移1、风格迁移是什么&#xff1f;2、步骤1&#xff09;训练2&#xff09;迁移 二、DNN模块1、什么是DNN模块2、DNN模块特点3、流程图4、图像预处理功能 三、案例实现1、数据预处理2、加载模型 总结 前言 风格迁移&#xff08;Style Transfer&#xff0…...

使用bitNet架构

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、配置二、报错总结 前言 大型语言模型&#xff08;LLM&#xff09;面临的挑战&#xff1a;高能耗、高内存需求、部署门槛高。 微软提出 BitNet 架构&#x…...

OpenCV中的光流估计方法详解

文章目录 一、引言二、核心算法原理1. 光流法基本概念2. 算法实现步骤 三、代码实现详解1. 初始化设置2. 特征点检测3. 光流计算与轨迹绘制 四、实际应用效果五、优化方向六、结语 一、引言 在计算机视觉领域&#xff0c;运动目标跟踪是一个重要的研究方向&#xff0c;广泛应用…...

Java集合框架详解与使用场景示例

Java集合框架是Java标准库中一组用于存储和操作数据的接口和类。它提供了多种数据结构&#xff0c;每种数据结构都有其特定的用途和性能特点。在本文中&#xff0c;我们将详细介绍Java集合框架的主要组成部分&#xff1a;List、Set和Queue&#xff0c;并通过代码示例展示它们的…...

多模态融合【十九】——MRFS: Mutually Reinforcing Image Fusion and Segmentation

目录 一.摘要 二.Introduction 三. 背景与动机 四.方法 4.1. 概述 4.2. IGM-Att模块 4.3. PC-Att模块 4.4. 任务头 五.实验 5.1. 数据集与实现细节 5.2. 语义分割 5.3. 图像融合 5.4. 消融研究 5.5. IGM-Att和PC-Att的应用增益 5.6. 复杂度讨论 5.7. 目标检测的…...

音频转文字-在线工具包及使用记录

资料来源&#xff1a;https://zhuanlan.zhihu.com/p/269603431&#xff08;多种方案&#xff09; 视频教程&#xff1a;https://www.youtube.com/watch?vL1H5ov4WTBg https://github.com/openai/whisper // 创建虚拟环境 python -m venv myvnev// 激活虚拟环境 source myvne…...

集合-进阶

Collection collection的遍历方式 迭代器遍历 不依赖索引 import java.util.ArrayList; import java.util.Collection; import java.util.Iterator;public class mycollection {public static void main(String[] args) {//1.创建集合并添加元素Collection<String> co…...

【阿里云】阿里云 Ubuntu 服务器无法更新 systemd(Operation not permitted)的解决方法

零、前言 目前正在使用的Ubuntu服务器中&#xff0c;仅阿里云&#xff08;不止一台&#xff09;出现了这个问题&#xff0c;因此我判定是阿里云服务器独有的问题。如果你的服务器提供商不是阿里云&#xff0c;那么这篇文章可能对你没有帮助。 如果已经因为升级错误导致依赖冲突…...

wpf DataGrid 行选择 命令绑定

在WPF中实现DataGrid行选择与命令绑定的MVVM模式,可通过以下方式结合代码示例实现: 1. ‌基础绑定与命令触发(SelectionChanged事件绑定)‌ 通过Interaction.Triggers捕获SelectionChanged事件,并绑定到ViewModel中的命令: <DataGrid ItemsSource="{Binding I…...

【认知思维】验证性偏差:认知陷阱的识别与克服

什么是验证性偏差 验证性偏差&#xff08;Confirmation Bias&#xff09;是人类认知中最普遍、最根深蒂固的心理现象之一&#xff0c;指的是人们倾向于寻找、解释、偏爱和回忆那些能够确认自己已有信念或假设的信息&#xff0c;同时忽视或贬低与之相矛盾的证据。这种认知偏差影…...

大容量存储的高性能 T-BOX 方案对智能网联汽车的支撑

在智能网联汽车快速发展的当下&#xff0c;车载 T-BOX&#xff08;Telematics Box&#xff09;作为车辆与云端互联的核心枢纽&#xff0c;其性能和可靠性直接决定了用户体验的上限。米客方德&#xff08;MK&#xff09;推出的基于 STM32H7RX 主控芯片与 MKDV4GIL-AST&#xff0…...

Linux 内核网络协议栈:从 Socket 类型到协议注册的深度解析

Linux 内核的网络协议栈是一个复杂而高效的体系,涉及多层次的协议处理与数据流转。本文通过分析核心数据结构(如 inetsw 数组、sock_type 枚举)和关键函数(如 inet_add_protocol),深入探讨其工作原理与设计哲学。 一、Socket 类型与 sock_type 枚举 1.1 Socket 类型的定…...

vim,gcc/g++,makefile,cmake

一、vim&#xff1a;你的小帮手——文本编辑器 它是干嘛的&#xff1f; 想象你的代码就像是写在一本“程序的笔记本”里&#xff0c;vim就是一个超级厉害的“数字笔记本”或“文字编辑器”。 它有什么用&#xff1f; 编写代码&#xff1a;编辑、修改你的源代码代码高亮&…...

解决 CentOS 7 镜像源无法访问的问题

在国内使用 CentOS 系统时&#xff0c;经常会遇到镜像源无法访问或者下载速度慢的问题。尤其是默认的 CentOS 镜像源通常是国外的&#xff0c;如果你的网络环境无法直接访问国外服务器&#xff0c;就会出现无法下载包的情况。本文将介绍如何修改 CentOS 7 的镜像源为国内镜像源…...

“傅里叶变换算法”来检测货物外形损坏

“傅里叶变换算法”来检测货物外形损坏 要使用傅里叶变换算法来检测货物外形损坏&#xff0c;首先需要理解基本概念。傅里叶变换是一种数学变换&#xff0c;用于将信号从时域&#xff08;或空间域&#xff09;转换到频域。在图像处理中&#xff0c;二维傅里叶变换可以用来分析…...

python打卡day24

可迭代对象、OS模块 知识点回顾&#xff1a; 元组可迭代对象os模块 作业&#xff1a;对自己电脑的不同文件夹利用今天学到的知识操作下&#xff0c;理解下os路径 1.元组 在day3的打卡内容中就介绍了元组&#xff0c;跟列表比起来就是用了圆括号&#xff0c;有序可以重复&#x…...

MapReduce 入门实战:WordCount 程序

一、引言 在大数据处理领域&#xff0c;MapReduce 是一种开创性的编程模型和处理框架&#xff0c;它使得我们能够高效地在大规模分布式系统上处理海量数据。而 WordCount 程序作为 MapReduce 的经典入门案例&#xff0c;堪称大数据领域的 “Hello World”&#xff0c;帮助无数…...