配置注入
ServiceComb提供将配置属性注入到Java对象字段的特性,并提供通配符支持。 Java对象可以是一个Java Bean,或是一个拥有public字段的类。
配置注入对象
我们首先设计两个Java类用于注入配置属性,分别用来演示不使用注解和使用注解的场景。
/*
使用ServiceComb注解
*/
@InjectProperties(prefix = "root") //指定该model关联的配置属性的前缀
public class ConfigWithAnnotation {
/*
此处的prefix属性值"override"会覆盖标注在类定义的@InjectProperties注解的prefix属性值"root",keys属性可以为一个字符串数组并且数组元素下标越小优先级越高
这里会按照如下顺序的属性名称查找配置属性,直到找到已被配置的配置属性,则停止查找:
1)override.high
2)override.low
*/
@InjectProperty(prefix = "override", keys = {"high", "low"})
public String strValue;
//keys支持通配符,并在可以在将配置属性注入的时候指定通配符的代入对象。
@InjectProperty(keys = "${key}.value")
public int intValue;
//通配符的代入对象可以是一个字符串List,优先级遵循数组元素下标越小优先级越高策略
@InjectProperty(keys = "${full-list}")
public float floatValue;
//keys属性也支持多个通配符,优先级如下:首先通配符的优先级从左到右递减,然后如果通配符被代入List,遵循List中元素index越小优先级越高策略。
@InjectProperty(keys = "${low-list}.a.${high-list}.b")
public long longValue;
//可以通过注解的defaultValue属性指定默认值。如果字段未关联任何配置属性,定义的默认值会生效,否则默认值会被覆盖
@InjectProperty(defaultValue = "abc")
public String strDef;
}
/*
不使用ServiceComb注解
*/
public class ConfigNoAnnotation {
/*
如果未提供@InjectProperties和@InjectProperty注解,会默认使用字段名作为配置属性名。注意类名不作为前缀起作用。
此处将配置属性 strValue 绑定到该字段
*/
public String strValue;
}
执行注入
我们可以通过以下示例代码来执行注入:
将配置属性注入到无@InjectProperties
和@InjectProperty
注解的对象上:
ConfigNoAnnotation config = SCBEngine.getInstance().getPriorityPropertyManager().createConfigObject(ConfigNoAnnotation.class);
将配置属性注入到有@InjectProperties
和@InjectProperty
注解的对象上:
- 将名称为root.k.value的配置属性注入到一个ConfigWithAnnotation对象的intValue字段
- ConfigWithAnnotation对象的longValue字段按以下顺序查找已配置的配置属性进行注入:
- root.low-1.a.high-1.b
- root.low-1.a.high-2.b
- root.low-2.a.high-1.b
- root.low-2.a.high-2.b
- ConfigWithAnnotation对象的floatValue字段按以下顺序查找已配置的配置属性进行注入:
- root.l1-1
- root.l1-2
ConfigWithAnnotation config = SCBEngine.getInstance().getPriorityPropertyManager().createConfigObject(ConfigWithAnnotation.class,
"key", "k",
"low-list", Arrays.asList("low-1", "low-2"),
"high-list", Arrays.asList("high-1", "high-2"),
"full-list", Arrays.asList("l1-1", "l1-2")
);
最后不管是有无注解的属性注入,都要显式地回收配置注入对象
priorityPropertyManager.unregisterConfigObject(config)
参考
当前内容版权归 servicecomb 或其关联方所有,如需对内容或内容相关联开源项目进行关注与资助,请访问 servicecomb .