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

万字拆解 LLM 运行机制:Token、上下文与采样参数稻

springboot自动配置

自动配置了大量组件,配置信息可以在application.properties文件中修改。

当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类,springboot会自动配置MyBatis相关的bean)。

springboot使用默认配置来设置这些功能,开发人员也可以自定义配置来覆盖默认配置。

这些配置信息如何生效的?

通过@ConfigurationProperties注解将配置信息注入到组件中的属性类的。属性类一般以Properties结尾。比如tomcat组件的ServerProperties类,就是将配置信息中server开头的配置注入到属性中,比如server.port=8080会被绑定到属性中

@ConfigurationProperties("server")

public class ServerProperties {

private @Nullable Integer port;

private @Nullable InetAddress address;

.....

}

自动配置是按需加载的

springboot提供很多自动配置类,这些自动配置不是全部生效,它是按需加载的,导入了哪个启动器,则该启动器对应的配置类才会被加载。

任何启动器都会关联一个启动器:spring-boot-Starter,它是springboot框架最核心的启动器。

spring-boot-Starter又关联引入spring-boot-auto从figure。所有的自动配置类都在这里。

自动配置类用来创建相应的组件。

按需加载如何实现?

使用条件注解可以实现按需加载。

条件注解基于某些条件决定是否应该创建一个bean。这些注解通常用在自动配置类上,以确保只有在特定条件满足时才会应用相应的配置。

条件注解可以用在类上,也可以用在方法上。

常见的条件注解有:

@ConditionalOnClass 指定类存在时才创建bean

@ConditionalOnMissingClass 指定类不存在时才创建bean

@ConditionalOnBean 容器中存在指定bean时才创建bean

@ConditionalOnMissingBean 容器中不存在指定bean时才创建bean

@ConditionalOnProperty 配置文件中存在指定属性时,才创建bean

@ConditionalOnResource 指定资源存在时才创建bean

@ConditionalOnWebApplication 应用程序是Web应用时才创建bean

@ConditionalOnNotWebApplication 应用程序不是Web应用时才创建bean

修改默认的包扫描规则

修改扫描规则有2种方式:

在主入口类上添加以下注解的任意一个都可以修改包扫描规则(扫描com包及其子孙包)

@ComponentScan("com")

@SpringBootApplication(scanBasePackages = "com")

自动配置的实现原理

程序从main方法开始执行,主入口类上使用@SpringBootApplication进行标注

@SpringBootApplication是复合注解,代表以下三个注解的功能

a. @SpringBootConfiguration:它被@Configuration标注。表明主入口类是一个配置类,此时该配置开始加载。

b. @ComponentScan 默认扫描主入口类所在包及其子孙包,因此spring-boot-autoconfigure 自动配置类是无法加载的,那么这些自动配置类又是怎么生效的呢?

c. @EnableAutoConfiguration 该注解的作用就是启用自动配置

@EnableAutoConfiguration 被@Import({AutoConfigurationImportSelector.class})标注

? @Import({AutoConfigurationImportSelector.class})的作用是将AutoConfigurationImportSelector作为一个bean加载到Ioc容器中

? 这个bean的作用是:负责收集和选择所有符合条件的自动配置类。

总结

运行环境准备阶段

引入Web启动器

最终传递引入了自动配置的jar包

自动配置的jar包中有152个自动配置类,到此运行环境准备完毕

运行阶段

@EnableAutoConfiguration 启用自动配置,将152个自动配置类全部加载到Ioc容器中。然后根据开发场景筛选出必须得自动配置类

自动配置类加载了很多组件

每个组件需要的数据来自属性类

属性类的属性来自配置文件

总之一句话。导入启动器,修改配置文件。就可以完成对应功能的开发。

springmvc配置

# 让springboot的静态资源处理失效

spring.web.resources.add-mappings=false

# 配置静态资源的访问URL

spring.mvc.static-path-pattern=/**

# 静态资源文件存储位置默认配置

spring.web.resources.static-locations=classpath:/META-INF/resources/, classpath:/resources/, classpath:/static/, classpath:/public/

springboot对静态资源是如何处理的?

什么样的URL ?访问哪个位置上的资源文件?

webjars

webjars是现在前后端分离中比较重要的一种静态资源打包方式。

webjars是一种常用的前端库(如jQuery)打包成jar包的形式,方便在java程序中使用。

webjars提供了一种标准化的方式来管理前端库,使其更容易集成到java项目中,并且可以利用Maven的依赖管理功能。

org.webjars.npm

vue

3.5.12

默认规则是:当请求路径是/wbjars/**,则会去classpath:/MEAT-INF/resources/webjars/找。

静态资源缓存处理

静态资源缓存是指浏览器的缓存行为,浏览器可以缓存(js、CSS、图片、声音、视频)到浏览器中,下一次用户访问同样的资源就直接从缓存中获取,不再从服务器获取,这样能减少服务器压力,提高相应效率。

可以通过配置来修改默认的缓存机制。

#静态资源缓存设置

#缓存有效期设置

spring.web.resources.cache.period=3600

# 缓存控制设置

spring.web.resources.cache.cachecontrol.max-age=20

# 是否启用最后一次修改时间的比对

spring.web.resources.cache.use-last-modified=true

静态index.html的支持

spring会自动处理位于静态资源目录下的index.html(文件名必须是index.html),使其成为应用程序的主页。

注意:此时不能配置静态资源访问url(spring.mvc.static-path-pattern),必须使用默认的配置

favicon.ico

将favicon.ico放在静态资源根目录下,就会自动生效。

spring boot的web手动配置(静态资源处理)

编写代码的方式

第一种方式 实现WebMvcConfigurer接口

// 添加这个注解后,表示不再使用springboot提供的默认配置

// @EnableWebMvc

@Configuration

public class WebConfig implements WebMvcConfigurer {

// 静态资源处理需要重写的方法

@Override

public void addResourceHandlers(ResourceHandlerRegistry registry) {

// 使用注册器registry 绑定 pathPatterns 以及真实的静态资源文件存储路径

registry.addResourceHandler("/abc/**") // 配置路径访问模式

.addResourceLocations("classpath:/static1/", "classpath:/static2/", "classpath:/static3/"); // 配置静态资源路径

}

}

第二种方式

@Configuration

public class WebConfig2 {

@Bean

public WebMvcConfigurer addResourceHandlers() {

return new WebMvcConfigurer() {

@Override

public void addResourceHandlers(ResourceHandlerRegistry registry) {

registry.addResourceHandler("/abc/**") // 配置路径访问模式

.addResourceLocations("classpath:/static1/", "classpath:/static2/", "classpath:/static3/"); // 配置静态资源路径

}

};

}

}

web请求的路径匹配

# 前端请求的url 匹配到controller中的某个方法

# 使用ant风格的路径匹配规则,默认值是path_pattern_matcher

# path_pattern_matcher兼容且支持ant风格

# 在ant风格中** 可以出现在任何位置,但在path_pattern_matcher风格中,** 只能出现在末尾

# spring6 下的ant风格 ** 也只能出现在末尾

spring.mvc.pathmatch.matching-strategy=ant_path_matcher椭缕晃蹿

http://www.jsqmd.com/news/626664/

相关文章:

  • Coding Agent底层架构全解(极其详细),吃透6大核心组件,收藏这篇就够了!
  • 打字不如说话,说话不如截图——AI 代码助手的多模态输入实践捶
  • Spring Boot WebFlux 响应式原理
  • 从Windows换到麒麟V10 SP1,这7个自带神器让我彻底卸载了第三方管家软件
  • 08. Spring Boot 工程实践
  • PPO-Lagrangian安全强化学习实战:从原理到代码的深度拆解
  • GLM-. 全面支持与 Gemini CLI 集成:HagiCode 的多模型进化之路屯
  • 【AIOps时代熔断新范式】:融合Prometheus指标、LangChain调用链与强化学习的实时熔断控制器(已落地金融级AI中台)
  • 软件构建管理中的依赖管理优化
  • 从51到32位DSP核:手把手移植你的老8051项目到STC32G144K246(Ai8052U)
  • 09. 性能优化技巧
  • 再次革新 .NET 的构建和发布方式(一)蛊
  • 别再死记公式!图解雅可比迭代与高斯-赛德尔迭代的核心区别与收敛性
  • 告别手动对时!手把手教你用ESP32+手机热点自动获取网络时间(基于ESP-IDF最新框架)
  • 【电价预测】基于深度学习与 SHAP 可解释性分析的西班牙电力市场电价预测研究(Python代码实现)
  • 别再混淆了!手把手教你用Simulink仿真区分双三相与六相PMSM(附互感影响对比)
  • 2026年热门的臭氧老化试验箱用户口碑推荐厂家 - 品牌宣传支持者
  • 【AI Token中转】2026年AI Token代理站搭建实战:技术架构与运营策略
  • 数据库创新探索
  • 基于 MOPGA‑NSGA‑II 的电动车多目标路径优化研究—— 考虑路况、天气与充电约束(Matlab代码实现)
  • Springboot 实现多数据源(PostgreSQL 和 SQL Server)连接椿
  • 终结Agentic RAG乱象!首篇权威SoK论文:从定义、架构到落地的全体系指南
  • CANopen协议栈选型避坑指南:为什么在ZYNQ上我最终选择了CANFestival?
  • Mermaid在线编辑器:实时创建与协作图表的终极指南
  • SIMCOM模块HTTPS库:Azure IoT安全接入裸机方案
  • SLAM 技术路线已收敛:这几条才是未来主流!
  • ArcGIS Pro中协同区位熵方法在商业选址分析中的实战应用
  • 融合粒子群的改进鲸鱼优化算法无人机三维航迹规划(Python代码实现)
  • Python AI爬虫实战:爬取张雪峰微博并进行情感分析与词云可视化宜
  • Umi-OCR终极指南:免费离线OCR软件如何提升你的工作效率3倍