什么是Eureka?
Eureka是由netflix出台的服务治理组件,是在分布式系统中管理各个分布式节点之间的通信,注册的一个组件。譬如当我们打开手机登录微信的时候,我们的手机会给分布式系统发消息通知客户端微信已经开启了,实际上完成的是服务注册过程,同时我们需要获取好友列表,实际上完成的是分布式结点之间的发现过程。这两个过程的实施,都需要Eureka这样的服务治理组件的帮助。
Eureka由服务器和客户端组件组成。Eureka服务器端会维护一张注册表,服务器组件将所有微服务注册在这张服务清单中,包含主机与端口号,版本号以及通信协议。微服务将使用Eureka客户端进行注册与服务发现。客户端在应用初始化阶段注册服务,随后通过发送一定频率的报文(心跳)来维持与服务端的连接,如果心跳长时间连接不上,Eureka会默认服务器故障,并踢出管理范围。但是如果是Eureka故障或者网络故障而导致大面积的服务连接不上,这种方法会起到反作用,所以Netflix设置如果Eureka丢失大量微服务连接会进入到保护模式,在保护模式下丢失的微服务结点不会被踢出Eureka的管理范围中。
Eureka的优势是什么,为什么我们使用他?
- 集成在Spring Cloud 中, 可以轻松导入Maven项目中。
- 相比起zookeeper他的容错率更高,一台服务器的故障不会影响整个分布式系统的模式,eureka在一台服务器宕机的情况下,不会再进行选举,更符合微服务使用的实际情况。
Eureka的基础架构
Eureka架构是由三个基础组件构成:
- 服务注册中心: 服务注册中心部署在Eureka 的服务端中,它是由一张清单列表构成,提供服务注册和发现的功能。服务注册已在前文中提及,对于服务发现,他通过这张表的 “联系方式”中这个服务所依赖的其他服务,然后对这些服务进行调取。
- 服务提供者,也就是客户端,他负责通过yml或者properties文件的形式标注自己为可提供服务的对象,他会在服务注册中心中注册从而使得他的服务被其他结点可见。服务注册中心同时也可以是服务提供者,实现服务高可用。
- 服务消费者: 他通过服务注册中心发现服务,然后执行服务完成自己的任务。在Spring Cloud中服务消费者的任务由Ribbon或者Feign来完成,Ribbon是一个负载均衡器,他通过轮询算法处理提供者的服务。
Eureka服务搭建
1.首先在pom.xml中增加插件
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
- 在主函数上使用@EnableEurekaServer启动Eureka服务
@EnableEurekaServer
@SpringBootApplication
public class SpringCloudServiceRegistrationEurekaServerApplication {
@LoadBalanced
@Autowired
RestTemplate restTemplate;
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
- 添加客户端
server.port = 8060
spring.application.name = String-service
eureka.client.serviceUrl.defaultZone = http://localhost:8080/eureka/
@RestController
public class HelloController{
@RequestMapping(Value = "/hello", method = RequestMethod.Get)
public String show(){
return "Hello";
}
}
4.配置消费者
@RestController
public class consumerController{
@RequestMapping(Value = "/consumer", method = RequestMethod.Get)
@ResponseBody
public String consumer() {
return restTemplate.getForEntity("http://String-service/hello", String.class);
}
}