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

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

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

相关文章:

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

Spring Boot 启动时 converting PropertySource ... to ... 日志详解 1. 日志背景 在 Spring Boot 应用启动过程中,会加载并处理多种 配置源(如 application.properties、系统环境变量、命令行参数等)。这些配置源会被封装为 PropertySource…...

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

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

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

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

SwiftUI 常用控件简介

SwiftUI 是苹果公司推出的现代化声明式 UI 框架,用于构建 iOS、macOS、watchOS 和 tvOS 应用程序用户界面。以下是一些常用的 SwiftUI 控件: 1. 文本控件 Text: 显示一段文本。 2. 图像控件 Image: 显示图片,可以从系统图标、网络或本地资…...

HCIP-H12-821 核心知识梳理 (6)

ospf dr-priority命令默认值为1,取值范围为0~255.DHCPv6使用IPv6组播地址FF05::1:3用于中继代理和服务器之间的通信。VRF路由表里的OSPF外部路由允许被路由汇总(asbr-summary)在IS-IS网络中,直连的两台路由器不管是P2P网络类型或是Broadcast网…...

Docker 安装配置教程(配置国内源)

## 一、Windows 安装 Docker Desktop 1. 系统要求: - Windows 10 64位:专业版、企业版或教育版 - 必须开启 Hyper-V 和容器功能 - 至少 4GB 内存 2. 安装步骤: - 访问 Docker 官网下载 Docker Desktop - 双击安装程序 - 按照向导完成安装 - 重启电脑 ## 二、macOS 安装 Dock…...

初识分布式事务原理

事务是指符合ACID特性的操作就是事务,在同一个数据库中,如果要分别对表A和表B进行插入和删除操作,如果其中一个操作执行失败,可以对当前数据库进行回滚,使其回滚到执行操作前的状态,但是现有的系统架构都是…...

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

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

Qt本地化-检测系统语言

获取系统语言,可以通过QLocale的接口 // 获取系统默认区域设置QLocale systemLocale QLocale::system();// 获取语言代码 (例如 "zh", "en", "ja" 等)QString language systemLocale.name().split(_).first(); //输出zh// 或者直接…...

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

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

c++中iota容器和fill的区别

在C 中,std::iota 和 std::fill 都是标准库中的函数,用于对序列进行操作,它们的功能和用法如下: std::iota 功能:std::iota 函数用于将一个连续的递增序列赋值给指定范围的元素。它接受三个参数,第一个参…...

【CSS】层叠,优先级与继承(四):层叠,优先级与继承的关系

层叠,优先级与继承的关系 前文概括 【CSS】层叠,优先级与继承(一):超详细层叠知识点 【CSS】层叠、优先级与继承(二):超详细优先级知识点 【CSS】层叠,优先级与继承&am…...

jdk17的新特性

JDK 17 是 Java 的一个长期支持(LTS)版本,相较于 JDK 8 引入了许多新特性,下面从语法、性能、安全性等多个方面进行介绍: 语法层面 密封类(Sealed Classes) 简介:密封类和接口限制…...

C++如何分析和解决崩溃(crash)问题?如何查看core dump文件

在软件开发的世界中,C++作为一门高效且灵活的高级编程语言,广泛应用于系统编程、游戏开发、嵌入式系统以及高性能计算等领域。然而,正是由于其直接操作内存和资源的特性,C++程序在开发和运行过程中常常面临崩溃(crash)问题。这些崩溃不仅会中断程序的正常运行,还可能导致…...

Docker配置带证书的远程访问监听

一、生成证书和密钥 1、准备证书目录和生成CA证书 # 创建证书目录 mkdir -p /etc/docker/tls cd /etc/docker/tls # 生成CA密钥和证书 openssl req -x509 -newkey rsa:4096 -keyout ca-key.pem \ -out ca-cert.pem -days 365 -nodes -subj "/CNDocker CA" 2、为…...

Unity 创建、读取、改写Excel表格数据

1.导入EPPlus.dll、Excel.dll、Mysql.Data.dll、System.Data.dll;(我这里用的是:Unity2017.3.0) 2.代码如下: using System.Data; using System.IO; using UnityEngine; using OfficeOpenXml; using UnityEditor; us…...

[密码学实战]政务数据加密传输协议选型解析:IPSec、TLS与国密方案的实战选择

政务数据加密传输协议选型解析:IPSec、TLS与国密方案的实战选择 在政务数据加密传输的实际项目中,IPSec确实是一种常见方案,但并非唯一选择。政务系统的数据安全传输需综合考虑 网络层级、合规要求、性能开销 和 场景适配性 四大因素。本文结合国内政务项目实战经验,深度剖…...

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

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

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

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

Ubuntu 22.04安装IGH

查看设备是否支持 硬件 $ sudo lshw -class network -short H/W path Device Class Description/0/100/1c/0 enp1s0 network I211 Gigabit Network Connection /0/100/1c.1/0 enp2s0 network RTL8111/8168/8411 PC…...

【华为OD机试真题】232、统计射击比赛成绩 | 机试真题+思路参考+代码分析(C++)

题目描述 给定一个射击比赛成绩单,包含多个选手若干次射击的成绩分数,请对每个选手按其最高3个分数之和进行降序排名,输出降序排 名后的选手ID序列 条件如下: 1.一个选手可以有多个射击成绩的分数,且次序不固定 2.如果一个选手成绩少于3个,则认为选手的所有成绩无效,排名…...

pycharm调试typescript

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

Kotlin高阶函数 vs Lambda表达式:关键区别与协作关系

先说结论: ✅ 高阶函数既可以用 Lambda 表达式,也可以用函数引用! 在 Kotlin 中,高阶函数(Higher-Order Function)和 Lambda 表达式密切相关,但它们是两个不同的概念: ✅ 简单理解…...

什么是爬虫?——从技术原理到现实应用的全面解析 II

五、现代爬虫技术面临的挑战与突破 5.1 动态网页与反爬机制的博弈 随着前端技术的演进,大量网站采用JavaScript动态渲染内容,传统爬虫难以直接获取有效数据。以下为应对单页应用(SPA)的解决方案: from selenium import webdriver from selenium.webdriver.chrome.optio…...

spring-ai之Advisors API

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

App爬虫工具篇-mitmproxy

mitmproxy 是一个支持 HTTP 和 HTTPS 的抓包程序,类似 Fiddler、Charles 的功能,它通过控制台的形式和ui界面的方式 此外,mitmproxy 还有两个关联组件,一个是 mitmdump,它是 mitmproxy 的命令行接口,利用它可以对接 Python 脚本,实现监听后的处理;另一个是 mitmweb,它…...

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

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

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

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

ROS 快速入门教程02

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

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

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