application.properties 配置失效解决

问题场景:

Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
2023-07-03 23:04:02.731 ERROR 31816 --- [           main] o.s.boot.SpringApplication               : Application run failed

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'deptController': Injection of autowired dependencies failed; nested exception is java.lang.IllegalArgumentException: Could not resolve placeholder 'server.port' in value "${server.port}"
	at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:405) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1415) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:608) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:531) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:944) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:923) ~[spring-context-5.3.3.jar:5.3.3]
	at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:588) ~[spring-context-5.3.3.jar:5.3.3]
	at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:144) ~[spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:767) [spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759) [spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:426) [spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:326) [spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1311) [spring-boot-2.4.2.jar:2.4.2]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1300) [spring-boot-2.4.2.jar:2.4.2]
	at com.example.workersdateserve.WorkersDateServeApplication.main(WorkersDateServeApplication.java:12) [classes/:na]
Caused by: java.lang.IllegalArgumentException: Could not resolve placeholder 'server.port' in value "${server.port}"
	at org.springframework.util.PropertyPlaceholderHelper.parseStringValue(PropertyPlaceholderHelper.java:178) ~[spring-core-5.3.3.jar:5.3.3]
	at org.springframework.util.PropertyPlaceholderHelper.replacePlaceholders(PropertyPlaceholderHelper.java:124) ~[spring-core-5.3.3.jar:5.3.3]
	at org.springframework.core.env.AbstractPropertyResolver.doResolvePlaceholders(AbstractPropertyResolver.java:239) ~[spring-core-5.3.3.jar:5.3.3]
	at org.springframework.core.env.AbstractPropertyResolver.resolveRequiredPlaceholders(AbstractPropertyResolver.java:210) ~[spring-core-5.3.3.jar:5.3.3]
	at org.springframework.context.support.PropertySourcesPlaceholderConfigurer.lambda$processProperties$0(PropertySourcesPlaceholderConfigurer.java:175) ~[spring-context-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.AbstractBeanFactory.resolveEmbeddedValue(AbstractBeanFactory.java:936) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1321) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1300) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:640) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) ~[spring-beans-5.3.3.jar:5.3.3]
	at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) ~[spring-beans-5.3.3.jar:5.3.3]
	... 18 common frames omitted


Process finished with exit code 1

其中配置的server.port=8001,但是启动的时候却使用的是默认端口8080
便猜想application.properties文件失效

问题解决:

将:

<packaging>pom</packaging>

换成:

<packaging>jar</packaging>

就可解决问题。

问题说明:

<packaging>pom</packaging><packaging>jar</packaging>是Maven项目中常用的两种打包方式,它们在项目构建和生成的输出文件类型上有所区别。

  1. <packaging>pom</packaging>

    • 当项目的打包方式设置为pom时,表示该项目是一个父项目或聚合项目,不会生成实际的构建产物(如JAR或WAR文件)。
    • 父项目通常用于管理和组织多个相关的子项目,而不是作为可执行的代码库。
    • 父项目可以定义通用的依赖关系、插件配置和其他构建设置,并供子项目继承和共享。
  2. <packaging>jar</packaging>

    • 当项目的打包方式设置为jar时,表示该项目会生成一个可执行的JAR文件作为构建产物。
    • JAR文件通常包含编译后的类文件、资源文件和其他依赖项,可以作为一个独立的可运行程序或可供其他项目引用的库。
    • JAR文件可以包含main方法作为入口点,使其能够被直接执行。

总结:

  • <packaging>pom</packaging>用于父项目或聚合项目,不生成构建产物。
  • <packaging>jar</packaging>用于可执行的JAR项目,生成可执行的JAR文件作为构建产物。
  • <packaging>pom修改为jarapplication.properties生效了,这是由于构建的目录结构发生了变化。在pom项目中,通常不会将资源文件(如application.properties)打包到输出目录中,因为它本身不会生成构建产物。但在jar项目中,资源文件通常会被打包到JAR文件中,因此application.properties会被正确地加载和使用。
### Spring Boot `application.yml` 中配置 `server.port` 不生效解决方案 #### 1. 检查其他配置文件的存在及其顺序 当存在多个配置文件时,加载顺序决定了最终使用的配置。日志显示先加载了 `application.properties` 文件再加载了 `application.yml` 文件[^2]。由于 `.properties` 文件后于 `.yml` 加载,因此前者会覆盖后者中相同的属性设置。 #### 2. 确认环境变量或命令行参数未指定端口 有时开发者可能通过环境变量或者启动命令附加参数的形式指定了服务监听端口,这也会导致应用内配置失效。可以查看运行环境中是否存在相关设定以及应用程序的实际启动指令是否有额外的端口定义。 #### 3. 排除外部配置源的影响 除了本地资源外,Spring Boot 还支持从远程仓库或者其他位置获取配置信息。这些地方如果有同名项,则同样会造成冲突并影响到预期行为。确保所有潜在的数据来源都已得到审查并且不会干扰目标属性值的应用。 #### 4. 使用唯一配置方式简化排查过程 为了便于定位具体原因,在调试阶段建议暂时移除不必要的配置选项只保留单一形式(比如仅使用 `application.yml`)来测试是否恢复正常工作状态;待确认无误后再逐步恢复其它必要的自定义化调整措施。 ```yaml server: port: 8081 ``` 上述 YAML 片段展示了如何正确地在 `application.yml` 文件里声明服务器监听端口为 8081[^1]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ikkkp

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值