0

0

Java常用配置类库与Spring Configuration

P粉602998670

P粉602998670

发布时间:2026-01-12 17:50:01

|

800人浏览过

|

来源于php中文网

原创

java原生读配置易踩路径、编码、资源关闭等坑,应优先用classloader.getresourceasstream();spring boot中@configurationproperties失效多因注解缺失或yaml格式错误;profile需在application.properties中早于上下文加载时指定;配置中心选型需权衡运维成本与功能需求。

java常用配置类库与spring configuration

Java原生配置读取容易踩哪些坑

纯Java项目不用Spring时,Properties类仍是主力,但直接用FileInputStream加载配置文件极易出错:路径不对、编码乱码、资源未关闭、空指针。尤其在JAR包中读取application.properties时,new FileInputStream("config/application.properties")必然失败——它只找当前工作目录,不是类路径。

  • 优先用ClassLoader.getResourceAsStream()加载类路径下的配置,比如getClass().getClassLoader().getResourceAsStream("application.properties")
  • 显式指定编码,new Properties().load(new InputStreamReader(in, StandardCharsets.UTF_8)),避免Windows平台默认ISO-8859-1导致中文乱码
  • 别手动close()流——用try-with-resources包裹,否则InputStream泄漏会拖慢应用启动
  • 环境变量或JVM参数(如-Denv=prod)需用System.getProperty("env")读取,和Properties内容是两套体系,不能混为一谈

Spring Boot的@ConfigurationProperties绑定失效常见原因

明明写了@ConfigurationProperties(prefix = "app.db"),字段却一直是null或默认值,大概率是漏了三件事:没加@EnableConfigurationProperties(老版本)、没在配置类上加@Component或没被@Configuration标记、YAML/properties里键名拼错或缩进不合法。

  • Spring Boot 2.2+ 默认启用@ConfigurationProperties扫描,但必须保证配置类在组件扫描路径下,或显式用@EnableConfigurationProperties(MyConfig.class)
  • YAML中app:db:之间必须换行且db:顶格对齐,app: db: url: ...这种写法无效
  • 属性名用驼峰(maxConnection)对应配置项app.db.max-connection,中间用短横线分隔,不是下划线
  • 如果绑定List或Map,确保YAML结构正确,例如app.features: [login, pay]app.features[0]: login更可靠

Spring Profile切换时配置没生效?检查spring.profiles.active加载时机

application-dev.properties存在,spring.profiles.active=dev也写了,但日志里还是打印default——问题往往出在配置加载顺序上。Spring Boot在创建ApplicationContext前就确定Profile,此时application.properties里的spring.profiles.active才有效;若用-Dspring.profiles.active=dev启动,必须确保JVM参数在命令行最前面,且没被其他配置覆盖。

有道智云AI开放平台
有道智云AI开放平台

有道智云AI开放平台

下载
  • 优先在application.properties里写spring.profiles.active=dev,而不是依赖环境变量,避免容器或CI脚本干扰
  • 多个Profile用逗号分隔:spring.profiles.active=dev,mysql,不是空格或分号
  • 自定义ConfigurableEnvironment或使用SpringApplication.setAdditionalProfiles()属于高级用法,普通项目慎用,容易绕过自动配置逻辑
  • 验证是否生效:启动日志搜Active profiles,或注入Environment对象调用getActiveProfiles()打印

第三方配置中心(如Nacos、Apollo)与Spring Cloud Config怎么选

单体应用用application.yml足够;微服务规模上来后,硬编码配置到Git或本地文件就扛不住了。Spring Cloud Config适合已有Git运维流程的团队,但需要单独部署Config Server;Nacos/Apollo自带UI、灰度发布、监听回调,接入更快,但引入新中间件意味着多一个运维点。

立即学习Java免费学习笔记(深入)”;

  • Spring Cloud Config + Git:配置变更需提交Git + 触发POST /actuator/refresh,适合强审计要求场景
  • Nacos:用nacos-config-spring-boot-starter,配置监听靠长轮询,@NacosValue可直接注入,但要注意dataId命名规范(如${spring.application.name}-${spring.profiles.active}.yaml
  • Apollo:必须用apollo-client,配置变更自动刷新Bean,但要求AppIdapollo.meta严格匹配,测试环境常因apollo.meta=http://localhost:8080写错成IP导致连不上
  • 无论哪种,都别把敏感配置(密码、密钥)明文放配置中心——应结合KMS或Vault做加密解密层
spring:
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848
        data-id: myapp-dev.yaml
        group: DEFAULT_GROUP
        file-extension: yaml

配置中心不是银弹,动态刷新可能引发线程安全问题,比如@Value注入的String被并发修改——真要热更新,优先走@RefreshScope或监听回调重构逻辑,而不是赌字段原子性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

513

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

668

2023.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 847人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号