1 Eureka注册中心 1.1 需求分析 在前后端分离架构中,服务层被拆分成了很多的微服务,微服务的信息如何管理?Spring Cloud中提供服务注册中 心来管理微服务信息。 为什么 要用注册中心? 1、微服务数量众多,要进行远程调用就需要知道服务端的ip地址和端口,注册中心帮助我们管理这些服务的ip和 端口。 2、微服务会实时上报自己的状态,注册中心统一管理这些微服务的状态,将存在问题的服务踢出服务列表,客户 端获取到可用的服务进行调用。 1.3 Eureka注册中心 1.3.1 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中获取服务调用地址,进行远程调用。 1.3.2 Eureka Server搭建 1.3.2.1 单机环境搭建 1、创建xc-govern-center工程: 包结构:com.xuecheng.govern.center 2、添加依赖 在父工程添加:(有了则不用重复添加) [AppleScript] 纯文本查看 复制代码 ? 1 2 3 4 5 6 <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring‐cloud‐dependencies</artifactId> <version>Finchley.SR1</version> <type>pom</type> <scope>import</scope> </dependency> 在Eureka Server工程添加: [AppleScript] 纯文本查看 复制代码 ? 1 2 3 4 5 6 <dependencies> <!‐‐ 导入Eureka服务的依赖 ‐‐> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring‐cloud‐starter‐netflix‐eureka‐server</artifactId> </dependency> </dependencies> 3、启动类 [AppleScript] 纯文本查看 复制代码 ? 1 2 @EnableEurekaServer//标识这是一个Eureka服务 @SpringBootApplication public class GovernCenterApplication { public static void main(String[] args) { SpringApplication.run(GovernCenterApplication.class, args); } } 4、@EnableEurekaServer 需要在启动类上用@EnableEurekaServer标识此服务为Eureka服务