没有合适的资源?快使用搜索试试~ 我知道了~
Eureka核心源码分析,包含注册,剔除,服务发现,续约的分析
需积分: 0 1 下载量 150 浏览量
2022-12-30
22:21:23
上传
评论
收藏 6.52MB DOCX 举报
温馨提示
试读
18页
Eureka核心源码分析,包含注册,剔除,服务发现,续约的分析
资源推荐
资源详情
资源评论
Eureka 核心源码分析
Eureka 是 SpringCloud 的具体实现之一,提供了服务注册,发现,续约,撤销等功能。并且
我们使用 Eureka 的时候会将其分为客户端 client 和服务端 server。服务端用于作为注册中心,
而客户端则作为服务提供者和调用者。
我们引入了 Netflix 的 Eureka-client 这个 jar 包之后,其中包含了 DicoveryClient 这个类,其提
供了与 eureka-server 进行交互的方法,如 register(注册),renew(续约),cancel(注销)
等方法。
-----------------------------服务注册----------------------------------
首先是注册方法。
这个类中的注册方法首先调用 AbstractJerseyEurekaHttpClient 类的 register 方法:Jersey 是 一
个 Restful 请 求 服 务 的 框 架
下面是 Jersey 这个类中的 register 方法,他会从我们的配置文件中拿到我们设定的注册中心
的 URL 地址,然后向这个地址发送一个 post 请求(因为 post 请求在 Restful 风格中代表的是
添加),并且携带自己的 info 信息,这个 info 信息就是该 client 的配置文件中定义的信息。
通过 HTTP 请求向 server 发送完毕一个注册消息之后,就会构建一个响应结果。
当 eureka 启动的时候,会向我们指定的 serviceUrl 发送请求,把自己节点的数据以 post
请求的方式,数据以 json 形式发送过去。
当返回的状态码为 204 的时候,表示注册成功。
上面是客户端 client 的注册流程,那么发送注册请求之后,就需要 server 服务器端去保存这
个注册信息了。
在 ApplicationResource 这个类中,有一个 addInstance 方法,用于将我们的注册的实例添加到注
册中心去.
这个代码的前面是一堆的 if else 判断,用于对注册的实例信息进行验证.
然后进入这个 register 方法
可以发现注册信息过来了
在 这 里 做 了 两 个 功 能 :
1、 调 用 handleRegistration, 在 方 法 中 使 用 publishEvent 发 布 了 监 听 事 件 。 Spring 支 持 事 件 驱 动 , 可 以 监 听 者 模 式 进
行 事 件 的 监 听 , 这 里 广 播 给 所 有 监 听 者 , 收 到 一 个 服 务 注 册 的 请 求 。
2、 调 用 父 类 PeerAwareInstanceRegistryImpl 的 register 方 法 :
① 拿 到 微 服 务 的 过 期 时 间 , 并 进 行 更 新
② 将 服 务 注 册 交 给 父 类 完 成
③ 完 成 集 群 信 息 同 步 ( 这 个 会 在 后 面 说 明 )
调 用 父 类 AbstractInstanceRegistry 的 register 方 法 , 在 这 开 始 真 正 开 始 做 服 务 注 册 :
之后这里开始调用父类 AbstractInstanceRegistry 的 register 方法,在这开始真正开始做服务
注册:
先说一下在这个类中定义的 Eureka-server 的服务注册列表的结构:
ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>> registry;
ConcurrentHashMap 中外层的 String 表示服务名称;spring.application.name
Map 中的 String 表示服务节点的 id (也就是实例的 instanceid);
Lease 是一个心跳续约的对象,InstanceInfo 表示实例信息。
重要的类:
--------------------------------------client 发送注册请求----------------------------
DiscoveryClient 里面的 register()方法完后注册的总体构造
AbstractJerseyEurekaHttpClient 里面的 register()方法具体发送注册请求(post)
-------------------------------------------下面是 server 中的处理-----------------
InstanceRegistry 里面 register()方法接受客户端的注册请求
PeerAwareInstanceRegistryImpl 里面调用父类的 register()方法实现注册
AbstractInstanceRegistry 里面的 register()方法完成具体的注册保留数据到 map 集合
保存服务实例数据的集合:
第一个 key 是应用名称(全大写) spring.application.name
Value 中的 key 是应用的实例 id
eureka.instance.instance-id
剩余17页未读,继续阅读
资源评论
ZhangBlossom
- 粉丝: 4w+
- 资源: 239
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Picasso_v3.1 2.ipa
- chromedriver-mac-arm64.zip
- 蓝zapro.apk
- chromedriver-linux64.zip
- UCAS研一深度学习实验-MNIST手写数字识别python源码+详细注释(高分项目)
- 基于Python和PyTorch框架完成的一个手写数字识别实验源码(带MINIST手写数字数据集)+详细注释(高分项目)
- 基于Matlab在MNIST数据集上利用CNN完成手写体数字识别任务,并实现单层CNN反向传播算法+源代码+文档说明(高分项目)
- NVIDIA驱动、CUDA和Pytorch及其依赖
- 基于SVM多特征融合的微表情识别python源码+项目说明+详细注释(高分课程设计)
- html动态爱心代码一(附源码)
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功