Eureka服务注册中心的使用

1.为什么使用

当服务很多时,单靠代码手动管理是很麻烦的,需要一个公共组件,统一管理多服务,包括服务是否正常运行,等

Eureka用于**服务注册, 但是目前官网已经停止更新**

2.服务治理和服务注册发现

Eureka服务注册中心的使用

Eureka服务注册中心的使用

3.Eureka与Dubbo的系统架构

Eureka服务注册中心的使用

4.版本差异

​ eurka最新的依赖变了

Eureka服务注册中心的使用

推荐使用2020的版本

2020的版本 将客户端和服务端的依赖进行了分离

5.Eureka的服务端配置

5.1首先引入4中的2020版本的服务端的依赖

5.2修改yml配置文件

Eureka服务注册中心的使用

需要注意的是 eureka在分布式架构中都是以集群的方式存在的,所以 当我们搭建eureka集群环境是 多个eureka服务都是相互注册的 即 defaultZone:指向的是其他的eureka服务

5.3 设置主启动类

Eureka服务注册中心的使用

在启动类上启用eureka服务注解

6.其他服务以Eureka客户端 注册进Eureka服务

6.1引入eureka客户端依赖文件

Eureka服务注册中心的使用

###6.2修改yml配置文件

Eureka服务注册中心的使用Eureka服务注册中心的使用

6.3设置主启动类

Eureka服务注册中心的使用

###6.4实现 服务 的负载均衡

为了实现负载均衡 我们需要注册进eureka的服务要搭建集群

所以我们再搭建一个服务

Eureka服务注册中心的使用

Eureka服务注册中心的使用

此时我们在eureka中注册进了集群版的 支付服务

假设 一个订单服务访问支付服务实现 服务的负载均衡

创建订单服务

Eureka服务注册中心的使用

主启动类也要添加eureka客户端注解

中途其他编码操作不详细赘述 只介绍如何调用负载均衡服务

RestTemplate 配置

Eureka服务注册中心的使用

与以往不同的是 为了实现resttempalte调用服务时实现负载均衡 我们的调用url发生了改变

Eureka服务注册中心的使用

如果url不对的话 进入eureka的服务地址进行查看 注册进的服务名称即可

如 在这个项目中我们应进入 http://eureka7001:7001

如果能成功调用服务就代表我们成功搭建了 单机版的eureka服务注册中心,并且实现了订单服务调用负载均衡的支付服务!

7.Eureka集群环境搭建

7.1eureka服务注册中心集群搭建

启用两个eureka服务 并且 互相注册

Eureka服务注册中心的使用

Eureka服务注册中心的使用

###7.2 逻辑服务注册进 集群版eureka服务注册中心

其他的服务 将注册中心的地址修改为两个服务注册中心的url

比如:支付模块

Eureka服务注册中心的使用

如此,集群版的服务注册中心也搭建完成

在启动时 应率先启动两个eureka服务注册中心 再启动其他业务服务

接下来进入eureka7001查看服务

Eureka服务注册中心的使用

在逻辑服务中启用了修改主机名 修改完就是上图 status列的名称

但是并没有发现启用显示ip地址有什么变化

Eureka服务注册中心的使用

此时我们将鼠标放在服务上 会发现此时左下角已经成功显示 ip地址了

8.Eureka的自我保护机制

Eureka服务注册中心的使用

Eureka服务注册中心的使用

Eureka服务注册中心的使用Eureka服务注册中心的使用

eureka服务端配置:

Eureka服务注册中心的使用

客户端配置

Eureka服务注册中心的使用

此时启动erueka和支付服务 此时如果直接关闭了 支付服务, 那么erueka会直接删除其注册信息

[外链图片转存中…(img-KYKvJUqh-1596196146902)]

客户端配置

[外链图片转存中…(img-M0EvtWwC-1596196146904)]

此时启动erueka和支付服务 此时如果直接关闭了 支付服务, 那么erueka会直接删除其注册信息