Spring Boot 启动时 `converting PropertySource ... to ...` 日志详解

news2025/7/19 17:40:00

Spring Boot 启动时 converting PropertySource ... to ... 日志详解

在这里插入图片描述


1. 日志背景

在 Spring Boot 应用启动过程中,会加载并处理多种 配置源(如 application.properties、系统环境变量、命令行参数等)。这些配置源会被封装为 PropertySource 对象,并添加到 Spring 的 Environment 中。
日志中的 converting PropertySource ... to ... 表示 将原始配置数据转换为 PropertySource 对象,并记录其来源和类型。


2. 典型日志示例
Converting property source org.springframework.core.env.SpelExpressionPropertySource@xxx to map
Converting property source org.springframework.core.env.MapPropertySource@xxx [applicationConfig: [classpath:application.properties]] to map
Converting property source org.springframework.core.env.SystemEnvironmentPropertySource@xxx [systemEnvironment] to map
Converting property source org.springframework.core.env.SimpleCommandLinePropertySource@xxx to map

3. 核心概念
  • PropertySource:
    表示配置数据的来源,如文件、环境变量、内存 Map 等。Spring Boot 将所有配置源统一为 PropertySource 对象,并按优先级顺序管理。
  • Environment:
    Spring 的配置中心,包含所有 PropertySource,并提供统一的属性访问接口(如 getProperty())。
  • 转换过程:
    将不同类型的原始配置数据(如 Properties 文件、环境变量 Map)转换为 PropertySource 对象,并最终合并到 Environment 中。

4. 典型 PropertySource 类型及转换示例
日志条目PropertySource 类型来源转换说明
SystemEnvironmentPropertySource系统环境变量操作系统环境变量(如 JAVA_HOME将环境变量(如 SPRING_PROFILES_ACTIVE)转换为键值对,并添加到 Environment
MapPropertySource配置文件(如 application.properties类路径或外部配置文件PropertiesYAML 文件内容解析为 Map,并封装为 PropertySource
SimpleCommandLinePropertySource命令行参数启动参数(如 --server.port=8080将命令行参数(如 --key=value)转换为键值对。
RandomValuePropertySource随机值生成器Spring Boot 内置功能生成随机值(如 random.uuid),并作为属性源注册。

5. 转换流程详解
  1. 初始化 Environment:
    • Spring Boot 启动时创建 ConfigurableEnvironment 实例。
  2. 加载配置源:
    • 从多个来源(如系统环境变量、JVM 系统属性、配置文件、命令行参数)读取配置数据。
  3. 转换为 PropertySource:
    • 每个配置源被封装为对应的 PropertySource 实例(如 SystemEnvironmentPropertySource)。
  4. 按优先级排序:
    • 属性源按优先级顺序添加到 Environment,覆盖规则为:后加载的属性源覆盖先加载的
    • 优先级从高到低通常为:
      命令行参数 > 系统环境变量 > 配置文件 > 默认属性
  5. 日志记录转换过程:
    • 每次转换时输出 converting PropertySource ... to map,表示将配置源转换为 Map 格式并整合到 Environment

6. 常见 PropertySource 类型及用途
类型用途示例
SystemEnvironmentPropertySource系统环境变量注入SPRING_PROFILES_ACTIVE=dev
MapPropertySource配置文件加载application.properties 中的 server.port=8080
SimpleCommandLinePropertySource命令行参数覆盖java -jar app.jar --debug=true
RandomValuePropertySource动态生成随机值${random.uuid}

7. 日志的调试意义
  • 配置来源排查:
    通过日志确认哪些配置源被加载,例如环境变量是否生效。
  • 优先级验证:
    确认高优先级配置(如命令行参数)是否覆盖了低优先级配置(如默认值)。
  • 配置冲突诊断:
    若属性值不符合预期,可通过日志定位冲突的来源(如环境变量与配置文件冲突)。

8. 示例场景分析

假设日志中出现以下条目:

Converting property source org.springframework.core.env.MapPropertySource@xxx [applicationConfig: [classpath:application.properties]] to map
  • 含义:
    正在将 application.properties 文件中的配置转换为 MapPropertySource
  • 验证步骤:
    1. 检查 application.properties 是否存在于类路径下。
    2. 确认配置项是否被正确读取(如 server.port 是否生效)。

9. 总结
  • 日志意义: 记录 Spring Boot 将不同配置源转换为 PropertySource 的过程,帮助理解配置加载流程。
  • 关键点:
    • 属性源按优先级覆盖。
    • 系统环境变量、命令行参数优先级高于配置文件。
    • 可通过日志定位配置来源和冲突问题。

10. 扩展阅读
  • Spring Boot 文档: Externalized Configuration
  • 核心类:
    • org.springframework.core.env.PropertySource
    • org.springframework.boot.env.SystemEnvironmentPropertySourceEnvironmentPostProcessor
    • org.springframework.boot.env.RandomValuePropertySource

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2341380.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

分割数据集中.json格式标签转化成伪彩图图像

一、前言 图像分割任务中,分割数据集的转换和表示方式对于模型训练至关重要。目前主要有两种常见的分割结果表示方法: 1. 转化为TXT文件 这种方式通常使用一系列的点(坐标)来表示图像中每个像素的类别标签。每个点通常包含像素…

Linux之彻底掌握防火墙-----安全管理详解

—— 小 峰 编 程 目录: 一、防火墙作用 二、防火墙分类 1、逻辑上划分:大体分为 主机防火墙 和 网络防火墙 2、物理上划分: 硬件防火墙 和 软件防火墙 三、硬件防火墙 四、软件防火墙 五、iptables 1、iptables的介绍 2、netfilter/…

# 构建和训练一个简单的CBOW词嵌入模型

构建和训练一个简单的CBOW词嵌入模型 在自然语言处理(NLP)领域,词嵌入是一种将词汇映射到连续向量空间的技术,这些向量能够捕捉词汇之间的语义关系。在这篇文章中,我们将构建和训练一个简单的Continuous Bag of Words…

Collection集合,List集合,set集合,Map集合

文章目录 集合框架认识集合集合体系结构Collection的功能常用功能三种遍历方式三种遍历方式的区别 List集合List的特点、特有功能ArrayList底层原理LinkedList底层原理LinkedList的应用场list:电影信息管理模块案例 Set集合set集合使用哈希值红黑树HashSet底层原理HashSet集合元…

使用DDR4控制器实现多通道数据读写(九)

一、本章概括 在上一节中,我们概括了工程的整体思路,并提供了工程框架,给出了读写DDR4寄存器的接口列表和重点时序图。当然,对于将DDR4内存封装成FIFO接口,其中的重点在于对于读写DDR4内存地址的控制,相对于…

深度解析n8n全自动AI视频生成与发布工作流

工作流模版地址:Fully Automated AI Video Generation & Multi-Platform Publishing | n8n workflow template 本文将全面剖析基于n8n平台的这个"全自动AI视频生成与多平台发布"工作流的技术架构、实现原理和关键节点,帮助开发者深入理解…

pycharm调试typescript

前言 搜索引擎搜索调试typescript,都是vscode,但是没看懂。 vscode界面简洁,但是适配起来用不习惯,还是喜欢用pycharm。 安装软件 安装Node.js https://nodejs.org/zh-cn 判断是否安装成功 node -v npm install -g typescrip…

spring-ai之Advisors API

1、 Spring AI Advisors API 提供了一种灵活而强大的方法来拦截、 修改和增强 Spring 应用程序中的 AI 驱动的交互。 通过利用 Advisors API,开发人员可以创建更复杂、可重用和可维护的 AI 组件。主要优势包括封装重复的生成式 AI 模式、转换发送到大型语言模型 &…

JVM 系列:JVM 内存结构深度解析

你点赞了吗?你关注了吗?每天分享干货好文。 高并发解决方案与架构设计。 海量数据存储和性能优化。 通用框架/组件设计与封装。 如何设计合适的技术架构? 如何成功转型架构设计与技术管理? 在竞争激烈的大环境下&#xff0c…

【回眸】Tessy集成测试软件使用指南(一)新手使用篇

前言 这个专栏的文章前4篇都在记录如何使用Tessy进行单元测试,集成测试需要有一定单元测试基础,且做集成测试之前,需要做好单元测试,否则将会大幅增加软件单元代码纠错的代价。集成测试所花费的时间通常远远超过单元测试。如果直…

ROS 快速入门教程02

5. Node 节点 以智能手机为例,当我们使用智能手机的某个功能时,大多时候在使用手机的某个APP。同样当我们使用ROS的某个功能时,使用的是ROS的某一个或者某一些节点。 虽然每次我们只使用ROS的某一个或者某一些节点,但我们无法下…

vue+django+LSTM微博舆情分析系统 | 深度学习 | 食品安全分析

文章结尾部分有CSDN官方提供的学长 联系方式名片 文章结尾部分有CSDN官方提供的学长 联系方式名片 关注B站,有好处! 编号: D031 LSTM 架构:vuedjangoLSTMMySQL 功能: 微博信息爬取、情感分析、基于负面消极内容舆情分析…

HCIP实验二(OSPF网络配置与优化)

一.拓扑图与题目 1.R5为ISP,其上只能配置IP地址; R5与其他所有直连设备间均使用公有IP;环回地址为100.1.1.1/3 2.R4设备为企业出口路由器 3.整个0SPF环境IP基于172.16.0.0/16划分 4.所有设备均可访问R5的环回; 5.减少LSA的更新里,加快收敛&#xff0…

K8S的service详解

一。service的介绍 在K8S中,pod是访问应用程序的载体,我们可以通过pod的ip来访问应用程序,但是pod的ip地址不是固定的,这也意味着不方便直接采用pod的ip对服务进行访问,为了解决这个问题,K8S提供了service…

数据结构初阶:二叉树(四)

概述:本篇博客主要介绍链式结构二叉树的实现。 目录 1.实现链式结构二叉树 1.1 二叉树的头文件(tree.h) 1.2 创建二叉树 1.3 前中后序遍历 1.3.1 遍历规则 1.3.1.1 前序遍历代码实现 1.3.1.2 中序遍历代码实现 1.3.1.3 后序遍历代…

配置Intel Realsense D405驱动与ROS包

配置sdk使用 Ubuntu20.04LTS下安装Intel Realsense D435i驱动与ROS包_realsense的驱动包-CSDN博客 中的方法一 之后不通过apt安装包,使用官方的安装步骤直接clone https://github.com/IntelRealSense/realsense-ros/tree/ros1-legacy 从这一步开始 执行完 这一步…

【最新版】沃德代驾源码全开源+前端uniapp

一.系统介绍 基于ThinkPHPUniapp开发的代驾软件。系统源码全开源,代驾软件的主要功能包括预约代驾、在线抢单、一键定位、在线支付、车主登记和代驾司机实名登记等‌。用户可以通过小程序预约代驾服务,系统会估算代驾价格并推送附近代驾司机供用户选择&…

Linux:权限相关问题

文章目录 shell命令以及运行的原理Linux权限执行权限更改目录权限缺省权限粘滞位 shell命令以及运行的原理 操作系统分为内核和外壳程序,xshell是外壳程序,外壳程序包括我们windows桌面上的图形化界面,本质都是翻译给核心处理,再显…

AI数字人:元宇宙舞台上的闪耀新星(7/10)

摘要:AI数字人作为元宇宙核心角色,提升交互体验,推动内容生产变革,助力产业数字化转型。其应用场景涵盖虚拟社交、智能客服、教育、商业营销等,面临技术瓶颈与行业规范缺失等挑战,未来有望突破技术限制&…

【Linux】冯诺依曼体系结构及操作系统架构图的具体剖析

目录 一、冯诺依曼体系结构 1、结构图 2、结构图介绍: 3、冯诺依曼体系的数据流动介绍 4、为什么在该体系结构中要存在内存? 二、操作系统架构图介绍 1、操作系统架构图 2、解析操作系统架构图 3、为什么要有操作系统? 前些天发现了一…