LD is tigger forever,CG are not brothers forever, throw the pot and shine.
Modesty is not false, solid is not naive, treacherous but not deceitful, stay with good people, and stay away from poor people.
talk is cheap, show others the code,Keep progress,make a better result.
目录
概述
架构特性
设计思路
实现思路分析
Eureka Server的数据存储分为两层:数据存储层和缓存层。
Eureka Server的数据存储层是双层的ConcurrentHashMap,我们知道 ConcurrentHashMap 是线程安全高效的Map集合。
private final ConcurrentHashMap<String, Map<String, Lease>> registry= new ConcurrentHashMap<String, Map<String, Lease>>();
第一层的ConcurrentHashMap的key=spring.application.name也就是客户端实例注册的应用名;value为嵌套的ConcurrentHashMap。
第二层嵌套的ConcurrentHashMap的key=instanceId也就是服务的唯一实例id,value为Lease对象,Lease对象存储着这个实例的所有注册信息,包括IP、端口、属性等。
根据这个存储结构我们可以发现,Eureka Server 第一层都是存储着所有的服务名,以及服务名对应的实例信息,也就是说第一层都是按照服务应用名这个维度来切分存储:
应用名1:应用1实例 Map 应该名2:应用2实例 Map …
第二层是根据实例的唯一 ID 来存储的,那么按照这个结构最终的存储数据格式为:
拓展实现
无,
相关工具如下:
无
实验效果:(解决思路)
分析:
小结:
主要讲述了一些,里面有许多不足,请大家指正~