如非授权,禁止用于商业用途,转载请注明出处
作者:mynewworldyyl

往下看前,建议完成前面1到10小节

JMicro目前仅支持基于Zookeeper做配置管理,全部配置信息可以在ZK做增删改查,建议通过ZKUI做对配置做日常管理,非常方便( 【8】JMicro微服务-JMicro ZKUI

1. 使用

应用中只需要通过Cfg注解即可使用配置,如

    @Cfg("/defaultLimiterName")
    private String name;

    @Cfg(value="/TestRpcServiceImpl/MapParams-*")
    public Map<String,String> params = null;

Cfg注解唯一必填属性为value,表示配置的KEY,Key以“/”开始,组成ZK中配置路径的一部份。

@Target(FIELD)
@Retention(RUNTIME)
public @interface Cfg {

    /**
     * value值以“/”开始,以非“/”结束
     * 对于Map,可以以*号结尾,表示匹配的条目全部放Map中,Key即配置的Key值,字符串类型,通过Map的泛型解析Value的类型
     * 相对于org.jmicro.Config#CfgDir 或  org.jmicro.Config#ServiceConfigDir 的路径
     */
    public String value();

    /**
     * 是否是必填属性
     * @return
     */
    public boolean required() default false;

    /**
     * 配置改变监听器,如果配置的值改变时,系统会调用这个值作为名称的对应的方法,以通知应用配置值改变了
     * 方法名可以不带参数,或者带一个参数,参数的值即为修改后的最新值,系统 优先调用带参数同名方法。
     * @return
     */
    public String changeListener() default "";

    /**
     * 是否默认使用全局配置(org.jmicro.Config#CfgDir ZK中全局配置路径下的值)
     * 如果全局配置有值,则不使用服务级配置,否则优先使用服务级配置
     * org.jmicro.Config#ServiceConfigDir 路径下的值
     * @return
     */
    public boolean defGlobal() default true;
}

2.  通过API获取配置的值

代码中可以通过Config实例获取配置,如

Config中还有很多get开头的方法,用以获取不同配置来源的配置值,如getServiceParam获取服务实例级参数,getGlobalParam获取全局配置参数,getCommandParam取命令行参数,getValue按特定优先级获取参数 等等。

3. 配置信息源

Cfg注解按如下优先级取配置,从高到低分别为,如果高优先级获取到值,则不会去低优先级取值

  a. 命令行参数:启动JVM时,通过-D设置的参数,具有最高优先级;

  b. 服务实例级参数org.jmicro.Config#ServiceConfigDir,值可以实时修改生效;

  c. 服务级参数(目前未实现)值可以实时修改生效;

  d. 全局服务参数org.jmicro.Config#CfgDir,值可以实时修改生效;

  e. /META-INF/jmicro/*.properties目录下配置的参数;

f. 系统环境变量System.getProperty(key)

  g. 系统环境变量System.getenv(key)

Cfg注解就是按特定优先级获取参数,所以配置时特别注意优先级并按需要存放配置信息。

4. 默认值

如果代码中按如下方式编写,则在系统启动时,如果ZK中还不存在/TestRpcServiceImpl/defaultLimiterName对应值,系统会将当前值defaultLimit存储到ZK中,下次启动时就会默认使用这个值,并且这个值可以修改并持久生效,这就是为什么前面启动的很多服务都没有做任何配置就能启动的原因

    @Cfg("/TestRpcServiceImpl/defaultLimiterName")
    private String name="defaultLimit";

5. Map<String,Value>配置

如下代码,系统会将全部以/TestRpcServiceImpl/MapParams-打头(后面必须有*号)的Key对应的值加入到params中,KEY即是路径值,路径值必然是字符串,

所以params的KEY必须是字符串类型。

值可以是任意类型,如果是Java 8种基本数据类型,则直接转换,否则通过JSON反序列化为指定类型,通过泛型获取值的类型,所以这个Map参数必须通过泛型定义。

    @Cfg(value="/TestRpcServiceImpl/MapParams-*")
    public Map<String,String> params = null;

Map的Cfg注解的value必须以*号结尾

5. Collection<Value>配置

Collection包括List和Set,必须通过泛型定义元素类型。如下代码表示以/StaticResourceHttpHandler/staticResourceRoot_开头的配置值全部加到staticResourceRoots 列表中,changeListener指定有新值加入时,调用resourceRootChange方法。

@Cfg(value="/StaticResourceHttpHandler/staticResourceRoot_*", changeListener="resourceRootChange")
    private List<String> staticResourceRoots = new ArrayList<>();

resourceRootChange方法定义如下:

public void resourceRootChange(String root) {
        if(!staticResourceRoots.contains(root)) {
            return;
        }

        Set<String> clears = new HashSet<String>();
        for(String p : contents.keySet()) {
            if(p.startsWith(root)) {
                clears.add(p);
            }
        }

        for(String p : clears) {
            contents.remove(p);
        }
    }

这段代码的意思是如果当前web静态资源存在缓存中,则将其缓存删除,以使下次有资源请求时,重新从系统加载资源。

Collection另外一种配置方式,

@Cfg(value="/StaticResourceHttpHandler/staticResourceRoot", changeListener="resourceRootChange")
    private List<String> staticResourceRoots = new ArrayList<>();

value不以*号结尾,配置注入时,将值以英文逗号做分隔,然后再将每个分隔后的值转化为集合元素类型值,并加入到集合中。

6. 数组配置

数组配置注入逻辑与集合相同,样例代码如下:

    @Cfg("/RouterManager/routerSort")
    private String[] routerSorts = {"tagRouter","serviceRouter","ipRouter"};

以上代码作用是注入服务路由优先级,因为只有一个属性值,所以省略了value名称。

7. ZK路径与properties,命令行参数配置风格兼容

在java的properties文件中,通常是使用"."号作为Key中单词的分隔符,而ZK的路径必须以"/"做分隔。在JMicro配置管理系统中对两者做兼容。以上5和6小节的value值又可以配置为以下等价形式:


@Cfg(value="StaticResourceHttpHandler.staticResourceRoot", changeListener="resourceRootChange")
private List<String> staticResourceRoots = new ArrayList<>();
@Cfg("RouterManager.routerSort") private String[] routerSorts = {"tagRouter","serviceRouter","ipRouter"};

用户可以在jmicro.example.provider及jmicro.example.comsumer相关代码中做测试,也可以自己按相同的方式写java项目做测试

JMicro微服务基础入门系列:

【1】JMicro微服务-RPC体验

【2】JMicro微服务-Hello World

【3】JMicro微服务-服务超时,重试,重试间隔

【4】JMicro微服务-服务限流

【5】JMicro微服务-熔断降级

【6】JMicro微服务-服务日志监控

【7】JMicro微服务-服务路由,负载均衡

【8】JMicro微服务-JMicro ZKUI

【9】JMicro微服务-发布订阅消息服

【10】JMicro微服务-API网关

【11】JMicro微服务-配置管理

【11】JMicro微服务-配置管理的更多相关文章

  1. 【13】JMicro微服务-ID生成与Redis

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到12小节 1. 微服务中ID地位 如果说前面小节的功能点是微服务的大脑,那么全局唯一ID则是微服务 ...

  2. 【12】JMicro微服务-Zookeeper

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到11小节 1. CuratorFramework支持 JMicro目前基于Zookeeper实现统 ...

  3. 【8】JMicro微服务-JMicro ZKUI

    ZKUI是一个开源项目,是一个查看,修改ZK数据非常方便的工具.JMicro基于ZK做服务治理,配置管理,因此使用ZKUI会提供非常大的方便. Github地址:https://github.com/ ...

  4. 【10】JMicro微服务-API网关

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到9小节 1. Api网关基本特性: Api网关作为对外网提供服务的基本入口,地位类似于NGINX, ...

  5. 【2】JMicro微服务-Hello World

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 1. 首先完成 JMicro微服务-RPC体验 的1到5步. 按默认方式启动ZK及Redis: JDK需要Java8及以上. ...

  6. 【3】JMicro微服务-服务超时,重试,重试间隔

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 接下来的内容都基于[2]JMicro微服务-Hello World做Demo 微服务中,超时和重试是一个最基本问题下面Dem ...

  7. JMicro微服务之超时&重试

    JMicro是本人开发的基于Java实现的微服务框架,当前正式版本为0.0.3,并已发布到maven中央仓库.项目源码github:https://github.com/mynewworldyyl/j ...

  8. 【6】JMicro微服务-服务日志监控

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl   1. 微服务相关 在前面的1到5节中,总共涉及服务提供者,服务消费者,服务监听服务,发布订阅服务,熔断器服务5种类型的猪 ...

  9. 【9】JMicro微服务-发布订阅消息服务

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 1. JMicro消息服务目前实现特性 a. JMicro只支持发布订阅消息服务,不支持队列式消息服务: b. 不支持消息持 ...

随机推荐

  1. 2018.09.11 poj2976Dropping tests(01分数规划)

    传送门 01分数规划板子题啊. 就是简单变形移项就行了. 显然 ∑i=1na[i]∑i=1nb[i]≤k" role="presentation" style=" ...

  2. vs2010 EF4.0 访问mysql

    需要安装mysql-connector-net-6.3.5 6.8.9的安装完后在dbfirst里找不到对应的提供程序 链接字符串里需要 指定下编码(如果不是gbk的话) <add name=& ...

  3. Docker 技巧:删除 Docker 容器和镜像

    默认安装完 docker 后,每次执行 docker 都需要运行 sudo 命令,非常浪费时间影响效率.如果不跟 sudo,直接执行 docker images 命令会有如下问题: Get http: ...

  4. UVa 11346 Probability (转化+积分+概率)

    题意:给定a,b,s,在[-a, a]*[-b, b]区域内任取一点p,求以原点(0,0)和p为对角线的长方形面积大于s的概率. 析:应该明白,这个和高中数学的东西差不多,基本就是一个求概率的题,只不 ...

  5. Python 插件(add-in)基础知识

    1)  Python插件为何物 一个插件(add-in)就是一个客户化,比如嵌入到ArcGIS应用程序中的工具条上的一系列工具,这些工具作为ArcGIS标准程序的补充可以为客户完成特殊任务. ArcG ...

  6. 池建强 博客 Mac使用技巧 第一季

    第1天: 今天推送的Mac技巧: 使用OS X,我们可以充分利用系统提供的多个Space,把不同的程序放到不同的Space,让我们的系统更有扩展性.如何增加Space呢?四指上推,在桌面的最上方会出现 ...

  7. windows下C++实现遍历本地文件

    1.假设本地 d:/ 下存放着0.txt,1.txt两个文件 2.开发工具VS,开发语言C++,怎么遍历得到两个文件呢? 废话不多,具体代码请看下面: /** * 入参:文件存放文件夹路径,例如D:\ ...

  8. Python学习-4.Python的模块加载(二)

    1.部分函数加载 from SameFolder import printSameFolder printSameFolder() 该代码指从SameFolder.py中加载printSameFold ...

  9. Spring Boot 2 实践记录之 封装依赖及尽可能不创建静态方法以避免在 Service 和 Controller 的单元测试中使用 Powermock

    在前面的文章中(Spring Boot 2 实践记录之 Powermock 和 SpringBootTest)提到了使用 Powermock 结合 SpringBootTest.WebMvcTest ...

  10. C#: 获取当前路径不要用Environment.CurrentDirectory

    网上大把文章写到C#获取当前路径的方法如下: // 获取程序的基目录. System.AppDomain.CurrentDomain.BaseDirectory // 获取模块的完整路径. Syste ...