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

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

springboot自动配置自动配置了大量组件配置信息可以在application.properties文件中修改。当添加了特定的Starter POM后springboot会根据类路径上的jar包来自动配置bean比如springboot发现类路径上的MyBatis相关类springboot会自动配置MyBatis相关的bean。springboot使用默认配置来设置这些功能开发人员也可以自定义配置来覆盖默认配置。这些配置信息如何生效的通过ConfigurationProperties注解将配置信息注入到组件中的属性类的。属性类一般以Properties结尾。比如tomcat组件的ServerProperties类就是将配置信息中server开头的配置注入到属性中比如server.port8080会被绑定到属性中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 指定类存在时才创建beanConditionalOnMissingClass 指定类不存在时才创建beanConditionalOnBean 容器中存在指定bean时才创建beanConditionalOnMissingBean 容器中不存在指定bean时才创建beanConditionalOnProperty 配置文件中存在指定属性时才创建beanConditionalOnResource 指定资源存在时才创建beanConditionalOnWebApplication 应用程序是Web应用时才创建beanConditionalOnNotWebApplication 应用程序不是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-mappingsfalse# 配置静态资源的访问URLspring.mvc.static-path-pattern/**# 静态资源文件存储位置默认配置spring.web.resources.static-locationsclasspath:/META-INF/resources/, classpath:/resources/, classpath:/static/, classpath:/public/springboot对静态资源是如何处理的什么样的URL 访问哪个位置上的资源文件webjarswebjars是现在前后端分离中比较重要的一种静态资源打包方式。webjars是一种常用的前端库如jQuery打包成jar包的形式方便在java程序中使用。webjars提供了一种标准化的方式来管理前端库使其更容易集成到java项目中并且可以利用Maven的依赖管理功能。org.webjars.npmvue3.5.12默认规则是当请求路径是/wbjars/**,则会去classpath:/MEAT-INF/resources/webjars/找。静态资源缓存处理静态资源缓存是指浏览器的缓存行为浏览器可以缓存js、CSS、图片、声音、视频到浏览器中下一次用户访问同样的资源就直接从缓存中获取不再从服务器获取这样能减少服务器压力提高相应效率。可以通过配置来修改默认的缓存机制。静态资源缓存设置缓存有效期设置spring.web.resources.cache.period3600# 缓存控制设置spring.web.resources.cache.cachecontrol.max-age20# 是否启用最后一次修改时间的比对spring.web.resources.cache.use-last-modifiedtrue静态index.html的支持spring会自动处理位于静态资源目录下的index.html文件名必须是index.html使其成为应用程序的主页。注意此时不能配置静态资源访问urlspring.mvc.static-path-pattern必须使用默认的配置favicon.ico将favicon.ico放在静态资源根目录下就会自动生效。spring boot的web手动配置静态资源处理编写代码的方式第一种方式 实现WebMvcConfigurer接口// 添加这个注解后表示不再使用springboot提供的默认配置// EnableWebMvcConfigurationpublic class WebConfig implements WebMvcConfigurer {// 静态资源处理需要重写的方法Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {// 使用注册器registry 绑定 pathPatterns 以及真实的静态资源文件存储路径registry.addResourceHandler(/abc/**) // 配置路径访问模式.addResourceLocations(classpath:/static1/, classpath:/static2/, classpath:/static3/); // 配置静态资源路径}}第二种方式Configurationpublic class WebConfig2 {Beanpublic WebMvcConfigurer addResourceHandlers() {return new WebMvcConfigurer() {Overridepublic 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-strategyant_path_matcher啃诜滓俣

相关文章:

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

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

Packr 跨平台打包最佳实践:Windows、Linux、macOS 全攻略

Packr 跨平台打包最佳实践:Windows、Linux、macOS 全攻略 【免费下载链接】packr Packages your JAR, assets and a JVM for distribution on Windows, Linux and Mac OS X 项目地址: https://gitcode.com/gh_mirrors/pac/packr Packr 是一款强大的跨平台打包…...

革命性Java包管理神器JitPack.io:10分钟快速上手指南

革命性Java包管理神器JitPack.io:10分钟快速上手指南 【免费下载链接】jitpack.io Documentation and issues of https://jitpack.io 项目地址: https://gitcode.com/gh_mirrors/ji/jitpack.io JitPack.io是一款革命性的Java包管理工具,它彻底改变…...

OpenAI API 报错 insufficient_quota 怎么办?4 种方案实测,最后一种最省心

上周五晚上十一点半,我正用 GPT-5 的 API 跑一个批量文本分类任务,跑到一半控制台突然刷屏红色报错:You exceeded your current quota, please check your plan and billing details. 错误码 insufficient_quota,HTTP 状态码 429。…...

欧姆龙CP1e与三台欧姆龙变频器485 Modbus通讯启停及频率给定控制

欧姆龙CP1e与三台欧姆龙变频器走485modbus通讯程 启停,频率给定控制在工业自动化领域,欧姆龙的CP1e系列PLC与变频器的通讯控制是一个常见的应用场景。今天,我们就来聊聊如何通过485 Modbus协议,实现CP1e与三台欧姆龙变频器的启停和…...

Qwen3.5-35B-A3B-AWQ-4bit多模态落地实践:图书馆古籍数字化图像元数据自动生成

Qwen3.5-35B-A3B-AWQ-4bit多模态落地实践:图书馆古籍数字化图像元数据自动生成 1. 项目背景与需求分析 古籍数字化是图书馆现代化转型的重要工作,传统流程需要人工逐页识别古籍内容并录入元数据,效率低下且容易出错。某省级图书馆收藏有10万…...

如何突破Wallpaper Engine资源提取难题?RePKG让资源处理效率提升300%

如何突破Wallpaper Engine资源提取难题?RePKG让资源处理效率提升300% 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 在动态壁纸创作和游戏资源开发领域,Wal…...

HJ170 01序列

题目题解(36)讨论(31)排行 简单 通过率:39.25% 时间限制:1秒 空间限制:256M 知识点模拟 校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。 描述 给定一个数组…...

OpenClaw 大结局——接入个人微信刚

本课概览 Microsoft Agent Framework (MAF) 提供了一套强大的 Workflow(工作流) 框架,用于编排和协调多个智能体(Agent)或处理组件的执行流程。 本课将以通俗易懂的方式,帮助你理解 MAF Workflow 的核心概…...

存储那么贵,何不白嫖飞书云文件空间荷

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

Ostrakon-VL-8B在零售场景落地实操:商品全扫描与空缺检测实战

Ostrakon-VL-8B在零售场景落地实操:商品全扫描与空缺检测实战 1. 零售场景的痛点与解决方案 在传统零售行业中,货架管理和商品盘点一直是耗时费力的工作。店员需要手动检查每个货架,记录商品库存情况,识别缺货位置。这个过程不仅…...

RWKV7-1.5B-g1a从零开始:Docker镜像拉取→服务启动→API调用完整指南

RWKV7-1.5B-g1a从零开始:Docker镜像拉取→服务启动→API调用完整指南 1. 模型简介 rwkv7-1.5B-g1a 是一个基于RWKV-7架构的多语言文本生成模型,特别适合以下场景: 基础问答文案续写简短总结轻量中文对话 这个模型在单卡24GB显存的GPU上就…...

Phi-4-reasoning-vision-15B作品集:15类真实办公截图(邮件/PPT/数据库/IDE等)理解效果

Phi-4-reasoning-vision-15B作品集:15类真实办公截图理解效果展示 1. 模型能力概览 Phi-4-reasoning-vision-15B是微软最新发布的视觉多模态推理模型,专门针对办公场景的视觉理解需求进行了优化。这个模型不仅能看懂图片内容,还能像专业人士…...

Lingyuxiu MXJ LoRA快速部署教程:开箱即用镜像+浏览器直连创作流程

Lingyuxiu MXJ LoRA快速部署教程:开箱即用镜像浏览器直连创作流程 1. 项目简介 Lingyuxiu MXJ LoRA创作引擎是一款专门为生成唯美真人风格人像而设计的智能图像生成系统。这个项目最大的特点就是专注于一种风格——Lingyuxiu MXJ风格,这种风格以细腻的…...

行式存储(Row-based Storage)和列式存储(Column-base Storage)简介穆

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

Phi-3-mini-4k-instruct-gguf快速上手:VS Code远程开发+Jupyter Notebook联调

Phi-3-mini-4k-instruct-gguf快速上手:VS Code远程开发Jupyter Notebook联调 1. 环境准备与快速部署 Phi-3-mini-4k-instruct-gguf是微软推出的轻量级文本生成模型,特别适合问答、文本改写、摘要整理等场景。本文将带你快速搭建开发环境,实…...

打字不如说话,说话不如截图——AI 代码助手的多模态输入实践嚎

整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等…...

亚洲美女-造相Z-TurboGPU算力优化:FP16量化+FlashAttention加速部署方案

亚洲美女-造相Z-Turbo GPU算力优化:FP16量化FlashAttention加速部署方案 想快速部署一个能生成高质量亚洲美女图片的AI模型,但又担心显存不够、速度太慢?今天分享一个经过深度优化的部署方案,让你用更少的资源,跑出更…...

KOOK艺术馆镜像免配置教程:8步完成Diffusers+Turbo环境搭建

KOOK艺术馆镜像免配置教程:8步完成DiffusersTurbo环境搭建 1. 引言:开启AI艺术创作之旅 想象一下,你坐在数字化的卢浮宫中,周围是梵高星空下的沉浸式创作环境,只需简单描述你的想法,就能生成专业级的艺术…...

Cosmos-Reason1-7B作品集:覆盖IMO/CMO/AMC等国际数学竞赛真题解析

Cosmos-Reason1-7B作品集:覆盖IMO/CMO/AMC等国际数学竞赛真题解析本文展示Cosmos-Reason1-7B在数学竞赛真题解析中的实际效果,所有案例均基于真实题目生成1. 工具简介:你的本地数学竞赛解题助手 Cosmos-Reason1-7B是一款专门针对推理任务优化…...

Servlet-JAVA【笔记】

JAVA_WEBTomcattomcat工作流程servlet的生命周期ServletConfigServletContextHttpServletRequestHttpServletResponse前端提交的数据和请求域里的数据的区别?应用域和请求域的区别?如何做到两个servlet之间交流/共享数据?请求转发和重定向区别…...

超详细图解:HTTPS 中的 SSL/TLS 完整握手过程(面试必背)

超详细图解:HTTPS 中的 SSL/TLS 完整握手过程(面试必背)摘要一、HTTPS 与 SSL/TLS 的关系二、SSL/TLS 握手:核心作用三、SSL/TLS 握手:标准流程(TLS 1.2 完整版)3.1 握手流程图3.2 逐步骤详细解…...

使用Alpine配置WSL ssh门户匚

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

栅极驱动核心原理 - DESAT保护

栅极驱动核心原理 - DESAT保护 它是一张电路实现图 + 文字说明图,旨在解释DESAT保护在驱动IC内部是如何通过硬件电路实现的——即如何利用恒流源、电阻、二极管和比较器来检测 VCEV_{CE}V...

深度解析TLS/SSL协议:工作原理、握手流程与网络安全应用

深度解析TLS/SSL协议:工作原理、握手流程与网络安全应用摘要一、TLS/SSL协议:基础定义1.1 TLS/SSL协议:是什么1.2 TLS/SSL协议:三大核心安全能力二、TLS/SSL协议:核心工作原理三、TLS/SSL协议:标准握手流程…...

计算机毕业设计:Python水网数据可视化与水位预测系统 Flask框架 数据分析 可视化 大数据 AI 线性回归 河流数据 水位预测(建议收藏)✅

博主介绍:✌全网粉丝50W,前互联网大厂软件研发、集结硕博英豪成立软件开发工作室,专注于计算机相关专业项目实战6年之久,累计开发项目作品上万套。凭借丰富的经验与专业实力,已帮助成千上万的学生顺利毕业,…...

qsort函数深度解析:如何自定义比较函数?

文章目录qsort函数深度解析:如何自定义比较函数?🚀什么是qsort函数?🤔自定义比较函数的重要性🎯基本示例:排序整数数组🔢排序字符串数组📝排序结构体数组🏗️…...

C语言中的泛型尝试:void_ + 函数指针

文章目录C语言中的泛型尝试:void* 函数指针 🧪什么是泛型?🤔C语言中的工具:void* 和函数指针 🛠️代码示例:泛型排序函数 📝进阶示例:泛型链表 📚优缺点分析…...

服务器Docker容器使用

0.基础指令 # 查看容器 docker ps docker images1.删除旧容器 docker rm -f novnc-test 2>/dev/null2.删除旧镜像 docker rmi ubuntu-novnc-vnc:22.04 2>/dev/null3.确认删除情况 docker ps -a | grep novnc-test docker images | grep ubuntu-novnc-vnc4.重新加载镜像 c…...

使用开源 Authentik 实现 AWS 单点登录

前言 懒得自己编了, Gemini 这样介绍 Authentik: 简单来说,Authentik 是一款功能极其强大的开源身份验证与访问管理 (IAM) 解决方案。 如果你觉得像 Okta 或 Auth0 这种商业服务太贵,或者觉得像 Keycloak 这种传统方案配置起来太头疼,那么…...