Skip to content

Latest commit

 

History

History
118 lines (88 loc) · 2.92 KB

README.md

File metadata and controls

118 lines (88 loc) · 2.92 KB

Smart-Config

智能配置:单体应用下的动态配置。 主要用来解决在单体应用没有配置中心时,想要动态变更配置。可以理解为单机版的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>
  1. 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; 
    
    } 
  2. 非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参数数据源支持