智能配置:单体应用下的动态配置。 主要用来解决在单体应用没有配置中心时,想要动态变更配置。可以理解为单机版的apollo
- 权限校验
- 动态变更配置
- webUi修改配置
- 支持非SpringBoot应用
- 无缝衔接
SpringBoot
应用 - 支持结构化数据(json,集合,对象)
- 轻量级无冗余第三方库
- 内嵌轻量级jetty服务器
- webUi支持中英文切换
- 支持springboot多配置文件
- 支持
spring.config.location
以及spring.profiles.active
- 支持启动参数修改webUi端口以及配置描述推断
<dependency>
<groupId>io.github.yangfeng20</groupId>
<artifactId>smart-config-core</artifactId>
<version>1.0.3</version>
</dependency>
- springboot3需要做单独的代码兼容,所以版本独立发布。如果使用的是springboot3,请在正常版本后添加[-springboot3];例如:
<dependency>
<groupId>io.github.yangfeng20</groupId>
<artifactId>smart-config-core</artifactId>
<version>1.0.3-springboot3</version>
</dependency>
-
Spring-Boot使用
主类添加注解
@EnableSmartConfig
@EnableSmartConfig public class XxxApplication { ApplicationContext application = SpringApplication.run(XxxApplication.class, args); }
使用@Value注解
public class AppConfig{ @Value("${configKey}") private String value; @JsonValue("${list:[1]}") private List<Integer> list; @JsonValue("${config.entity:{}}") private XxxEntity entity; }
-
非spring项目使用
创建LocalFileConfig对象,参数分别为webUi的端口,是否推断配置描述。
public class App{ public static void main(String[]args){ SmartConfig smartConfig = new LocalFileConfig(6767, true); List<String> list = new ArrayList<>(); list.add("com.maple.smart.config.test"); AbsConfigBootstrap bootstrap = new LocalConfigBootstrap(true, 6767,"classpath:application.properties", list); bootstrap.init(); } }
静态类的静态字段使用@SmartValue注解
public class AppConfig{ @SmartValue("配置key:默认值") private static String config1; @SmartValue("biz.name:abc") private static String bizName; @JsonValue("${list:[1]}") private static List<Integer> list; @JsonValue("${config.entity:{}}") private static XxxEntity entity; }
- Web-Ui默认端口:6767
- SpringBoot应用配置类被代理后请勿直接访问属性,而是通过getter访问
- 非Spring应用仅支持静态变量。
- spel支持
- 环境变量以及jvm参数数据源支持