1 需求分析
在前后端分离架构中,服务层被拆分成了很多的微服务,微服务的信息如何管理?Spring Cloud中提供服务注册中心来管理微服务信息。
为什么要用注册中心?
1、微服务数量众多,要进行远程调用就需要知道服务端的ip地址和端口,注册中心帮助我们管理这些服务的ip和端口。
2、微服务会实时上报自己的状态,注册中心统一管理这些微服务的状态,将存在问题的服务剔除服务列表,客户端获取到可用的服务进行调用。
2 Eureka介绍
Spring Cloud Eureka是对Netflix公司的Eureka的二次封装,它实现了服务治理的功能,Spring Cloud Eureka提供服务端与客户端,服务端即是Eureka服务注册中心,客户端完成微服务向Eureka服务的注册与发现,服务端和客户端均采用Java语言编写。下图显示了Eureka Server与Eureka Client的关系:
1、Eureka Server是服务端,负责管理各微服务节点的信息和状态。
2、在微服务上部署Eureka Client程序,远程访问Eureka Server将自己注册在Eureka Server
3、微服务需要调用另一个微服务时从Eureka Server中获取服务调用地址,进行远程调用。
3 Eureka Server搭建
3.1 单机环境搭建
1、创建xc-govern-center工程
2、添加依赖
在父工程添加:(有了则不用重复添加)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring‐cloud‐dependencies</artifactId>
<version>Finchley.SR1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
在Eureka Server工程添加:
<dependencies>
<!-- 导入Eureka服务的依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
3、启动类
@EnableEurekaServer //标识这是一个Eureka服务
@SpringBootApplication
public class GovernCenterApplication {
public static void main(String[] args) {
SpringApplication.run(GovernCenterApplication.class, args);
}
}
4、@EnableEurekaServer
需要在启动类上用@EnableEurekaServer标识此服务为Eureka服务
5、从其他服务拷贝application.yml和logback-spring.xml
application.yml的配置内容如下:
registerWithEureka:被其他服务调用时需向Eureka注册
fetchRegistry:需要从Eureka中查找要调用的目标服务时需要设置为true
serviceUrl.defaultZone :配置上报Eureka服务地址高可用状态配置对方的地址,单机状态配置自己
enable-self-perservation:自我保护设置,下边有介绍
eviction-interval-timer-in-ms:清理失效节点的间隔,在这个时间段内如果没有收到该节点的上报则将节点从服务列表中剔除。
5、启动Eureka Server
启动Eureka Server,浏览50101端口
说明:
Eureka Server有一种自我保护模式,当微服务不再向Eureka Server上报状态,Eureka Server会从服务列表中将此服务删除,如果出现网络异常情况(微服务正常),此时Eureka Server进入自保护模式,不再将微服务从服务列表删除。关闭自我保护功能,可以防止关闭的实例无法被服务注册中心剔除的问题。
3.2 高可用环境搭建
Eureka Server高可用环境需要部署两个Eureka Server,它们互相向对方注册。如果在本机启动两个Eureka需要注意两个Eureka Server的端口要设置不一样,这里我们部署一个Eureka Server工程,将端口可配置,制作两个Eureka Server启动脚本,启动不同的端口,如下图:
1、在实际使用时Eureka Server至少部署两台服务器,实现高可用。
2、两台Eureka Server互相注册。
3、微服务需要连接两台Eureka Server注册,当其中一台Eureka死掉也不会影响服务的注册与发现。
4、微服务会定时向Eureka Server发送心跳,报告自己的状态。
5、微服务从注册中心获取服务地址以RESTful方式发起远程调用。
配置如下:
1.端口可配置:
2、Eureka服务端的交互地址可配置
3、配置hostname
Eureka组成高可用,两个Eureka互相向对方注册,这里需要通过域名或主机名访问,这里我们设置两个Eureka服务的主机名分别为eureka01、eureka02。
完整的eureka配置如下:
4、在IDEA中制作启动脚本
启动1:
启动2:
注意:要在hosts文件中配置域名
运行两个脚本,分别浏览:
Eureka主画面如下:
4 服务注册
4.1 将服务注册到Eureka Server
下边实现cms向Eureka Server注册
1、在cms服务中添加依赖
2、在application.yml添加配置
3、在启动类上添加注解
在启动类上添加注解 @EnableDiscoveryClient ,表示它是一个Eureka的客户端
4、刷新Eureka Server查看注册情况