服务器route配置文件,spring-boot-route(二)读取配置文件的几种方式

dc25a6aed567a1f78fbd189afc43525a.png

spring-boot-route(二)读取配置文件的几种方式

76697f43b6dadf5352964015d0aea05b.png

Spring Boot提供了两种格式的配置文件,分别是properties 和 yml。Spring Boot最大的特点就是自动化配置,如果我们想修改自动化配置的默认值,就可以通过配置文件来指定自己服务器相关的参数。

配置文件集约管理了配置信息,如果把配置参数写到Java代码中,维护起来非常不方便,如果使用配置文件,我们可以统一管理,统一修改。我比较推荐使用yml格式的配置文件,YAML是专门用来写配置文件的语言,通常以yml为后缀,它的结构非常清晰,更易于阅读。

将自定义的配置写在配置文件中后,如果想要在java代码中使用配置,这时候就需要读取配置文件,读取配置文件的方式有三种,我们挨个介绍一下如果进行读取!

第一种:使用@Value注解读取

第一步:在配置文件中增加加入以下配置

config:

name: Java旅途

desc: spring-boot-route

第二部:新建Java类读取配置信息

@RestController

public class GetValue{

@Value("${config.name}")

private String name;

@Value("${config.desc}")

private String desc;

@GetMapping("getValue")

public String getValue(){

return "name="+name+";desc="+desc;

}

}

@Value注解使用简单,适合单个参数的注入。

第二种:使用@ConfigurationProperties读取

@ConfigurationProperties与@Value相比,更加适合读取数组类型的参数。

1. 获取单个对象

第一步:在yml文件中新建对象类型的配置信息

configs:

config:

name: Java旅途

desc: spring-boot-route

第二步:新建实体映射配置信息

@Component

@ConfigurationProperties(prefix = "configs.config")

@Data

public class Config{

private String name;

private String desc;

}

第三步:新建类测试是否获取到参数

@RestController

public class GetConfigurationProperties{

@Autowired

private Config config;

@GetMapping("/getConfig")

public String getConfig(){

return config.getName()+";"+config.getDesc();

}

}

2. 获取对象集合

第一步:在yml文件中新建数组类型的参数

configs:

config:

- name: Java旅途

desc: spring-boot-route

- name: javatrip

desc: spring-boot-yml

第二步:新建实体映射配置信息

@Component

@ConfigurationProperties(prefix = "configarr")

@Data

public class Configs{

private List config = new ArrayList<>();

@Data

public static class Config{

private String name;

private String desc;

}

}

第三步:新建测试类获取参数

@RestController

public class GetConfigurationProperties{

@Autowired

private Configs configs;

@GetMapping("/getConfigs")

public String getConfigs(){

String content = "";

List configList = configs.getConfig();

Map map = new HashMap<>();

for (Configs.Config bean : configList){

content += bean.getName()+";"+bean.getDesc()+",";

}

return content;

}

}

除了上面介绍的两种方式之外,还可以通过Spring Boot上下文的环境变量来读取配置文件信息,不过上面两种方式已经完全可以满足所有需求,这里就不再进行介绍了。

思考与扩展

如果多个配置文件具有相同的配置信息,那么如何读取特定的配置文件信息呢?

配置文件具有优先级,一般情况下,yml文件的优先级高于properties,这样就会导致properties的配置信息后加载,最后读取的时候就会properties的配置信息的优先级会更高。

上面介绍的两种读取配置文件的方式可以和另一个注解配合使用,@PropertySource常用的三个属性,一个是value用于指定配置文件,另一个是encoding用于指定编码,最后一个是factory,用于指定解析工厂。

这里需要注意一下:@PropertySource默认只会加载properties格式的文件,也就是我们如果指定了yml类型的文件是不会生效的,这时候就需要我们重写解析工厂。

先看看下默认的解析工厂源码:

public class DefaultPropertySourceFactory implements PropertySourceFactory{

public DefaultPropertySourceFactory(){

}

public PropertySource> createPropertySource(@Nullable String name, EncodedResource resource) throws IOException {

return name != null ? new ResourcePropertySource(name, resource) : new ResourcePropertySource(resource);

}

}

自定义解析工厂,实现PropertySourceFactory

public class YmlConfigFactory extends DefaultPropertySourceFactory{

@Override

public PropertySource> createPropertySource(String name, EncodedResource resource) throws IOException {

String sourceName = name != null ? name : resource.getResource().getFilename();

if (!resource.getResource().exists()) {

return new PropertiesPropertySource(sourceName, new Properties());

} else if (sourceName.endsWith(".yml") || sourceName.endsWith(".yaml")) {

Properties propertiesFromYaml = loadYml(resource);

return new PropertiesPropertySource(sourceName, propertiesFromYaml);

} else {

return super.createPropertySource(name, resource);

}

}

private Properties loadYml(EncodedResource resource) throws IOException{

YamlPropertiesFactoryBean factory = new YamlPropertiesFactoryBean();

factory.setResources(resource.getResource());

factory.afterPropertiesSet();

return factory.getObject();

}

}

第一步:新建两个配置文件,test.yml和test.properties,增加以下配置信息

spring:

value: javatrip123

remark: javatrip123

spring:

value: javatrip123

remark: javatrip123

第二步:指定配置文件映射配置文件内容

@Data

@Configuration

@PropertySource(value = {"classpath:test.yml"},encoding = "gbk")

@ConfigurationProperties(prefix = "spring")

public class Spring{

private String value;

private String remark;

}

第三步:新建类进行测试

@RestController

public class GetSource{

@Autowired

private Spring spring;

@GetMapping("get")

public String getSource(){

return spring.getRemark()+";"+spring.getValue();

}

}

此是spring-boot-route系列的第二篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同学有一个系统的认识。本文已收录至我的github,欢迎各位小伙伴star!

D:\Java\jdk1.8.0_211\bin\java.exe -XX:TieredStopAtLevel=1 -noverify -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-Dmanagement.endpoints.jmx.exposure.include=*" "-javaagent:D:\IntelliJ IDEA 2024.3.5\lib\idea_rt.jar=52828" -Dfile.encoding=UTF-8 -classpath D:\java\jdk1.8.0_211\jre\lib\charsets.jar;D:\java\jdk1.8.0_211\jre\lib\deploy.jar;D:\java\jdk1.8.0_211\jre\lib\ext\access-bridge-64.jar;D:\java\jdk1.8.0_211\jre\lib\ext\cldrdata.jar;D:\java\jdk1.8.0_211\jre\lib\ext\dnsns.jar;D:\java\jdk1.8.0_211\jre\lib\ext\jaccess.jar;D:\java\jdk1.8.0_211\jre\lib\ext\jfxrt.jar;D:\java\jdk1.8.0_211\jre\lib\ext\localedata.jar;D:\java\jdk1.8.0_211\jre\lib\ext\nashorn.jar;D:\java\jdk1.8.0_211\jre\lib\ext\sunec.jar;D:\java\jdk1.8.0_211\jre\lib\ext\sunjce_provider.jar;D:\java\jdk1.8.0_211\jre\lib\ext\sunmscapi.jar;D:\java\jdk1.8.0_211\jre\lib\ext\sunpkcs11.jar;D:\java\jdk1.8.0_211\jre\lib\ext\zipfs.jar;D:\java\jdk1.8.0_211\jre\lib\javaws.jar;D:\java\jdk1.8.0_211\jre\lib\jce.jar;D:\java\jdk1.8.0_211\jre\lib\jfr.jar;D:\java\jdk1.8.0_211\jre\lib\jfxswt.jar;D:\java\jdk1.8.0_211\jre\lib\jsse.jar;D:\java\jdk1.8.0_211\jre\lib\management-agent.jar;D:\java\jdk1.8.0_211\jre\lib\plugin.jar;D:\java\jdk1.8.0_211\jre\lib\resources.jar;D:\java\jdk1.8.0_211\jre\lib\rt.jar;D:\酒店预订\xm-hotel-manager\springboot\target\classes;D:\MAVEN\Repository\org\springframework\boot\spring-boot-starter-web\2.5.9\spring-boot-starter-web-2.5.9.jar;D:\MAVEN\Repository\org\springframework\boot\spring-boot-starter\2.5.9\spring-boot-starter-2.5.9.jar;D:\MAVEN\Repository\org\springframework\boot\spring-boot\2.5.9\spring-boot-2.5.9.jar;D:\MAVEN\Repository\org\springframework\boot\spring-boot-autoconfigure\2.5.9\spring-boot-autoconfigure-2.5.9.jar;D:\MAVEN\Repository\org\springframework\boot\spring-boot-starter-logging\2.5.9\spring-boot-starter-logging-2.5.9.jar;D:\MAVEN\Repository\ch\qos\logback\logback-cla
最新发布
04-03
<think>好的,我现在需要帮用户排查Spring Boot项目在JDK 1.8和Maven环境下启动时的配置问题。首先,我得理清可能的原因,然后一步步指导用户检查。 首先,用户提到的是配置问题,所以应该从项目的配置入手。常见的配置问题包括依赖冲突、JDK版本不匹配、Maven配置错误、Spring Boot自动配置问题,以及配置文件的问题。 第一步,检查JDK版本。用户用的是JDK 1.8,但有时候项目可能配置了更高的版本。需要确认pom.xml里的Java版本设置是否正确。比如,<java.version>1.8</java.version>是否正确,以及Maven编译插件的配置是否指向1.8。另外,用户的环境变量JAVA_HOME是否确实指向了1.8,有时候安装了多个JDK可能会有冲突。 接下来是Maven依赖问题。用户需要执行mvn clean install,并观察是否有依赖下载失败或冲突。特别是Spring Boot的starter依赖是否正确,版本是否统一。有时候不同的模块引用了不同版本的库,导致冲突。可以使用mvn dependency:tree命令查看依赖树,找出冲突的依赖,然后用<exclusions>排除。 然后是Spring Boot的自动配置。用户提供的引用[1]中,主启动类排除了DataSourceAutoConfiguration,这通常是因为项目没有配置数据源但引入了相关依赖。如果用户确实需要数据库,但排除了自动配置,会导致问题。需要检查是否误排除了必要的自动配置类,或者是否需要添加数据源配置。 配置文件方面,application.properties或application.yml中的配置是否正确。比如服务器端口、Eureka配置(引用[1]和[2]中的@EnableEurekaClient和@EnableDiscoveryClient)、数据库连接等。引用[3]提到URL从配置文件读取,需要确认配置文件中的属性是否正确,路径是否存在拼写错误,特别是baseurl、port、projectName这些属性是否设置正确。 启动类注解也是一个点。主类应该有@SpringBootApplication,而像@EnableEurekaClient或@EnableDiscoveryClient是否正确使用。网关服务(引用[2])需要对应的路由配置,否则可能无法启动。 日志分析很重要。用户应该查看启动日志中的ERROR或WARNING信息,特别是Bean创建失败、配置缺失、端口冲突等。比如DataSource相关的错误可能提示数据库配置问题,或者自动配置失败。 网络配置方面,比如Eureka服务器的地址是否正确,网关的路由规则是否正确定义。如果引用了其他服务,确保服务名称和端口匹配。 最后,建议用户提供具体的错误信息,这样能更精准地定位问题。比如,如果日志中有ClassNotFoundException,可能是依赖缺失;如果提示端口占用,需要更改server.port配置。 总结下来,需要分步骤检查JDK、Maven依赖、Spring Boot配置、启动类注解、配置文件以及日志信息,逐一排除可能的问题点。同时,结合用户提供的引用内容,重点查看排除的自动配置类和配置文件中的属性是否正确。</think>### Spring Boot项目启动配置问题排查指南(JDK1.8 + Maven) #### 一、基础环境验证 1. **JDK版本验证** - 检查`pom.xml`中Java版本配置: ```xml <properties> <java.version>1.8</java.version> </properties> ``` - 执行`mvn -v`确认Maven使用的JDK是否为1.8 - 验证环境变量`JAVA_HOME`指向JDK1.8路径[^1] 2. **Maven依赖完整性** - 执行`mvn clean install -U`强制更新依赖 - 检查是否存在红色依赖项(版本冲突) - 使用`mvn dependency:tree`分析依赖树 #### Spring Boot配置检查 1. **启动类注解验证** - 主类需包含`@SpringBootApplication` - 特殊配置如排除数据源: ```java @SpringBootApplication(exclude = DataSourceAutoConfiguration.class) // 适用于无数据库场景[^1] ``` 2. **配置文件检查** - 验证`application.properties/yml`路径正确性 - 检查关键配置项: ```properties server.port=8001 # 端口冲突是常见问题 eureka.client.service-url.defaultZone=http://localhost:8761/eureka # Eureka配置[^2] ``` #### 三、常见问题定位 1. **日志分析** - 关注首个`ERROR`日志出现的位置 - 典型错误模式: - `Field xxx required a bean of type yyy` → 缺少Bean定义 - `Port 8080 already in use` → 端口冲突 - `Failed to configure a DataSource` → 数据源配置问题 2. **自动配置排除验证** - 检查是否误排必要配置类: ```java // 正确排除姿势(仅当确实不需要数据源时) @SpringBootApplication(exclude = {DataSourceAutoConfiguration.class, DataSourceTransactionManagerAutoConfiguration.class}) ``` #### 四、网关服务专项检查(参考引用[2]) 1. **路由配置验证** ```yaml spring: cloud: gateway: routes: - id: payment_route uri: lb://CLOUD-PAYMENT-SERVICE predicates: - Path=/payment/** ``` 2. **服务发现配置** - 确认`@EnableDiscoveryClient`已启用 - 检查注册中心可达性 #### 五、配置管理规范(参考引用[3]) 1. **统一配置实践** ```java // 推荐从配置文件读取URL String baseUrl = properties.getProperty("baseurl") + properties.getProperty("port") + "/" + properties.getProperty("projectName");[^3] ``` 2. **配置文件优先级检查** - `application.properties` > `application.yml` - Profile特定配置(如`application-dev.properties`)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值