元数据的操作设计
在介绍 link-flow 的使用时,涉及到了 区域、组、版本,并根据将配置中的信息,放到了服务的元数据中。 配置信息:
spring:
application:
name: consumer-service
cloud:
link-flow:
metadata:
group: test-group
version: 1.0
zone: test-zone-1
注册中心以 Nacos 为例,查看服务中的元数据:
这就需要设计对服务元数据的操作了,而Nacos和Eureka的操作是不同的,就需要将两者进行适配,这就需要进行分层次的设计,希望小伙伴理解完后,自己在设计项目时,会掌握这种设计思想。
接口 MetaDataOperation 的设计
既然是要兼容 Nacos 和 Eureka,那么肯定首先要将元数据操作的行为先设计好接口,叫 MetaDataOperation
public interface MetaDataOperation {
/**
* 规则
* @return 结果
* */
ConfigRule getConfigRule();
/**
* 获取服务id
* @param server 服务
* @return 结果
* */
String getServiceIdFromServer(ServiceInstance server);
/**
* 获取版本
* @param server 服务
* @return 结果
* */
String getVersionFromServer(ServiceInstance server);
/**
* 获取版本
* @return 结果
* */
String getVersion();
/**
* 获取区域
* @return 结果
* */
String getZone();
/**
* 获取灰度
* @return 结果
* */
String getGray();
/**
* 获取区域
* @param server 服务
* @return 结果
* */
String getZoneFromServer(ServiceInstance server);
/**
* 获取灰度
* @param server 服务
* @return 结果
* */
String getGrayFromServer(ServiceInstance server);
/**
* 获取组
* @return 结果
* */
String getDefaultGroupKey();
/**
* 获取组
* @return 结果
* */
String getGroup();
/**
* 获取服务id
* @return 结果
* */
String getServiceId();
/**
* 规则
* @param configRule 规则
* */
void setRule(ConfigRule configRule);
/**
* 获取组
* @param server 服务
* @return 结果
* */
String getGroupFromServer(ServiceInstance server);
/**
* 获取信息
* @return 结果
* */
Map<String,String> getInfo();
}
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
- 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
