在自己的SpringBoot或者自定义 starter 模块项目中,往往需要一些自定义配置。
自定义XxlJob Properties 配置
@Data
@RefreshScope
public class CesXxlJobProperties {
public static final String PREFIX = "xxl.job";
@Value("${xxl.job.admin.addresses}")
private String adminAddresses;
@Value("${xxl.job.accessToken}")
private String accessToken;
@Value("${xxl.job.executor.appname}")
private String appName;
@Value("${xxl.job.executor.address:}")
private String address;
@Value("${xxl.job.executor.ip:}")
private String ip;
@Value("${xxl.job.executor.port:0}")
private int port;
@Value("${xxl.job.executor.logpath:}")
private String logPath;
@Value("${xxl.job.executor.logretentiondays:30}")
private int logRetentionDays;
}
在application.yml
使用idea往往会提示Springboot
自带的配置而不会提示我们自己的配置类。 这个是怎么实现的呢。如下图
自定义配置怎么出现提示呢?
使用spring-boot-configuration-processor实现,其作用是生产配置元数据。
1. 在resources添加/META-INF/spring-configuration-metadata.json
,也可使用additional-spring-configuration-metadata.json
json文件如下格式:
{
"groups": [],
"hints": [],
"properties": [
{
"name": "xxl.job.admin.addresses",
"type": "java.lang.String",
"description": "调度中心部署根地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行\"执行器心跳注册\"和\"任务结果回调\";为空则关闭自动注册;"
},
{
"name": "xxl.job.accessToken",
"type": "java.lang.String",
"description": "执行器通讯TOKEN [选填]:非空时启用;"
},
{
"name": "xxl.job.executor.appname",
"type": "java.lang.String",
"defaultValue": "localhost",
"description": "执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册"
},
{
"name": "xxl.job.executor.address",
"type": "java.lang.String",
"defaultValue": "8080",
"description": "执行器注册 [选填]:优先使用该配置作为注册地址,为空时使用内嵌服务 ”IP:PORT“ 作为注册地址。从而更灵活的支持容器类型执行器动态IP和动态映射端口问题。"
},
{
"name": "xxl.job.executor.ip",
"type": "java.lang.String",
"defaultValue": "",
"description": "执行器IP [选填]:默认为空表示自动获取IP,多网卡时可手动设置指定IP,该IP不会绑定Host仅作为通讯实用;地址信息用于 \"执行器注册\" 和 \"调度中心请求并触发任务\";"
},
{
"name": "xxl.job.executor.port",
"type": "java.lang.Integer",
"defaultValue": "9999",
"description": "执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;"
},
{
"name": "xxl.job.executor.logpath",
"type": "java.lang.String",
"defaultValue": "",
"description": " 执行器运行日志文件存储磁盘路径 [选填] :需要对该路径拥有读写权限;为空则使用默认路径;"
},
{
"name": "xxl.job.executor.logretentiondays",
"type": "java.lang.String",
"defaultValue": "30",
"description": "执行器日志文件保存天数 [选填] : 过期日志自动清理, 限制值大于等于3时生效; 否则, 如-1, 关闭自动清理功能;"
}
]
}
2. 出现的效果如下:
自动生成 spring-configuration-metadata
spring-configuration-metadata.json
文件可以自动生成吗?
答案是肯定的,不然维护这个json
文件都会累死人!
- 你只需要在你的
pom.xml
中加入这个依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
<scope>provided</scope>
</dependency>
- 必须要添加
@ConfigurationProperties
注解 - 你在写配置属性类的时候,有好好写注释,那么自动提示就都会带上了,比如下面这样:
@Data
@RefreshScope
@ConfigurationProperties(prefix = CesXxlJobProperties.PREFIX)
public class CesXxlJobProperties {
public static final String PREFIX = "xxl.job";
/**
* 调度中心部署根地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调";为空则关闭自动注册;
*/
@Value("${admin.addresses}")
private String adminAddresses;
/**
* 执行器通讯TOKEN [选填]:非空时启用;
*/
@Value("${accessToken}")
private String accessToken;
/**
* 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册
*/
@Value("${executor.appname}")
private String appName;
/**
* 执行器注册 [选填]:优先使用该配置作为注册地址,为空时使用内嵌服务 ”IP:PORT“ 作为注册地址。从而更灵活的支持容器类型执行器动态IP和动态映射端口问题。
*/
@Value("${executor.address:}")
private String address;
/**
* 执行器IP [选填]:默认为空表示自动获取IP,多网卡时可手动设置指定IP,该IP不会绑定Host仅作为通讯实用;地址信息用于 "执行器注册" 和 "调度中心请求并触发任务";
*/
@Value("${executor.ip:}")
private String ip;
/**
* 执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;
*/
@Value("${executor.port:0}")
private int port;
/**
* 执行器运行日志文件存储磁盘路径 [选填] :需要对该路径拥有读写权限;为空则使用默认路径;
*/
@Value("${executor.logpath:}")
private String logPath;
/**
* 执行器日志文件保存天数 [选填] : 过期日志自动清理, 限制值大于等于3时生效; 否则, 如-1, 关闭自动清理功能;
*/
@Value("${executor.logretentiondays:30}")
private int logRetentionDays;
}
当你再次编译的时候,spring-configuration-metadata.json
文件就自动出现啦!不过,这里还有个前提,你在写配置属性类的时候,有好好写注释,那么自动提示就都会带上了,比如下面这样:
手动添加生成提示
除了自动生成配置有些我们还有自定义,可以写在additional-spring-configuration-metadata.json
文件中
additional-spring-configuration-metadata.json
文件中存在的提示会覆盖自动生成(合并)的对应属性,若自动生成的没有此属性则自动增加。