跳到主要内容

元数据的操作设计

在介绍 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的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠