Eureka服务注册中心的使用
1.为什么使用
当服务很多时,单靠代码手动管理是很麻烦的,需要一个公共组件,统一管理多服务,包括服务是否正常运行,等
Eureka用于**服务注册, 但是目前官网已经停止更新**
2.服务治理和服务注册发现
3.Eureka与Dubbo的系统架构
4.版本差异
eurka最新的依赖变了
推荐使用2020的版本
2020的版本 将客户端和服务端的依赖进行了分离
5.Eureka的服务端配置
5.1首先引入4中的2020版本的服务端的依赖
5.2修改yml配置文件
需要注意的是 eureka在分布式架构中都是以集群的方式存在的,所以 当我们搭建eureka集群环境是 多个eureka服务都是相互注册的 即 defaultZone:指向的是其他的eureka服务
5.3 设置主启动类
在启动类上启用eureka服务注解
6.其他服务以Eureka客户端 注册进Eureka服务
6.1引入eureka客户端依赖文件
###6.2修改yml配置文件
6.3设置主启动类
###6.4实现 服务 的负载均衡
为了实现负载均衡 我们需要注册进eureka的服务要搭建集群
所以我们再搭建一个服务
此时我们在eureka中注册进了集群版的 支付服务
假设 一个订单服务访问支付服务实现 服务的负载均衡
创建订单服务
主启动类也要添加eureka客户端注解
中途其他编码操作不详细赘述 只介绍如何调用负载均衡服务
RestTemplate 配置
与以往不同的是 为了实现resttempalte调用服务时实现负载均衡 我们的调用url发生了改变
如果url不对的话 进入eureka的服务地址进行查看 注册进的服务名称即可
如 在这个项目中我们应进入 http://eureka7001:7001
如果能成功调用服务就代表我们成功搭建了 单机版的eureka服务注册中心,并且实现了订单服务调用负载均衡的支付服务!
7.Eureka集群环境搭建
7.1eureka服务注册中心集群搭建
启用两个eureka服务 并且 互相注册
###7.2 逻辑服务注册进 集群版eureka服务注册中心
其他的服务 将注册中心的地址修改为两个服务注册中心的url
比如:支付模块
如此,集群版的服务注册中心也搭建完成
在启动时 应率先启动两个eureka服务注册中心 再启动其他业务服务
接下来进入eureka7001查看服务
在逻辑服务中启用了修改主机名 修改完就是上图 status列的名称
但是并没有发现启用显示ip地址有什么变化
此时我们将鼠标放在服务上 会发现此时左下角已经成功显示 ip地址了
8.Eureka的自我保护机制
eureka服务端配置:
客户端配置
此时启动erueka和支付服务 此时如果直接关闭了 支付服务, 那么erueka会直接删除其注册信息
[外链图片转存中…(img-KYKvJUqh-1596196146902)]
客户端配置
[外链图片转存中…(img-M0EvtWwC-1596196146904)]
此时启动erueka和支付服务 此时如果直接关闭了 支付服务, 那么erueka会直接删除其注册信息