Spring Cloud 基于 Netflix 的几个开源项目进行了封装,提供包括服务注册与发现(Eureka),智能路由(Zuul),熔断器(Hystrix),客户端负载均衡(Ribbon)等在内的核心组件。

在微服务系统中,服务少则十几、几十个,多则上百、几百个(据悉 Netflix 的云平台上运行了500多个微服务),这些微服务通过相互调用来为用户提供功能。那么一个服务调用另一个服务是如何进行的,如何定位到另一个服务的地址?代码中写死,还是配置文件中配置?显然对于服务数量较多的系统,这两种方式先不说后续维护,光写起来就很痛苦。于是,对于微服务架构来说,服务的自动注册与发现就成为非常核心的功能,Eureka就是来负责实现这个功能的。

本系列文章与示例均基于最新的Spring Cloud Hoxton版编写。

Eureka

Eureka是一个基于REST的服务,包括Eureka Server与Eureka Client两个端。Eureka Server作为服务注册中心接受Eureka Client的注册及获取其它服务的地址信息。基本架构如下图所示:

其中

  • Eureka Server: 作为服务注册中心,提供服务注册与发现功能接口

  • Service Provider: 服务提供者,将自身服务注册到服务注册中心,供其它服务消费者发现与调用

  • Service Consumer: 服务消费者,从服务注册中心发现服务,并通过一些负载均衡客户端来调用(比如Ribbon或Feign)

很多时候同一个应用可能既是服务提供者,也是服务消费者——自己作为服务方,为其它服务提供接口,同时也调用其它服务的接口来完成自身的业务逻辑。


Eureka Server

Eureka Server的搭建非常简单,其部署可分为单实例部署与多实例集群部署,一般开发测试环境可以使用单实例部署,但生产环境出于高可用要求,可进行多实例集群部署。

1. 在pom.xml中添加依赖

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

为了方便版本引入,可以在pom中添加依赖管理,这样spring cloud相关的starter依赖就不需要指定版本了(如上省略了version)

<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>

2. 在启动类上添加注解 @EnableEurekaServer

@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication { public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}

3. 在application.yml 或 application.properties配置文件中添加配置(个人比较倾向于yml,两者区别可自行百度)

spring:
application:
name: spring-cloud-eureka
profiles:
active: single server:
port: 8761 ---
spring:
profiles: single
eureka:
instance:
hostname: localhost
client:
registerWithEureka: false
fetchRegistry: false
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ ---
spring:
profiles: peer1
server:
port: 8761
eureka:
instance:
hostname: peer1
client:
serviceUrl:
defaultZone: http://peer2:8762/eureka/,http://peer3:8763/eureka/
---
spring:
profiles: peer2
server:
port: 8762
eureka:
instance:
hostname: peer2
client:
serviceUrl:
defaultZone: http://peer1:8761/eureka/,http://peer3:8763/eureka/
---
spring:
profiles: peer3
server:
port: 8763
eureka:
instance:
hostname: peer3
client:
serviceUrl:
defaultZone: http://peer1:8761/eureka/,http://peer2:8762/eureka/

在该配置文件中,实际上是定义了两种模式,其中默认的profile single是单实例模式, peer1, peer2, peer3组成多实例模式。

  • eureka.client.registerWithEureka:表示是否将自身注册到Eureka Server,默认为true,单实例模式下一般设置为false,否则会在启动时报连接不到服务器的错误
  • eureka.client.fetchRegistry:表示是否从Eureka Server获取注册服务列表,默认为true,同样在单实例模式下设置为false

  • eureka.client.serviceUrl.defaultZone:Eureka Server的地址,多实例模式下多个地址以“,”隔开,多个实例之间只要有一条路线连通,则总会将注册信息进行同步

4. 启动

对于单实例模式,如果按如上配置,则直接启动程序即可。启动完成后,访问 http://localhost:8761,即可查看Eureka Server的相关信息,如

上图所示,当前没有Eureka Server的副本也没有任何服务注册。

对于多实例集群模式,则需要根据不同的profile启动多个实例,

mvn clean package
cd target
java -jar springcloud-eureka-1.0-SNAPSHOT.jar --spring.profiles.active=peer1
java -jar springcloud-eureka-1.0-SNAPSHOT.jar --spring.profiles.active=peer2
java -jar springcloud-eureka-1.0-SNAPSHOT.jar --spring.profiles.active=peer3

启动完成后,打开 http://localhost:8761, 可以看到Eureka Server已经存在副本与注册的服务了(Eureka将自身作为一个服务完成了注册)

上述操作如果是在单机进行,则需要在hosts文件中添加映射,linux下是/etc/hosts,windows10 下是C:\Windows\System32\drivers\etc\hosts,

127.0.0.1 peer1
127.0.0.1 peer2
127.0.0.1 peer3

Eureka Client

Eureka Client一般集成在各个微服务中,集成也非常简单。

1. pom.xml中添加依赖

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

2. application.yml配置文件中添加配置

eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
instance:
prefer-ip-address: true
instance-id: ${spring.application.name}:${random.uuid}

如果是多实例集群模式,则 eureka.client.serviceUrl.defaultZone 可以配置多个地址,“,”号分隔。

  • eureka.client.*:发现服务的配置参数

  • eureka.instance.*:注册服务的配置参数, 如上 eureka.instance.prefer-ip-address 设置为true表示服务注册时使用IP,而不是hostname; eureka.instance.instance-id 配置服务实例的ID,默认为 ${spring.cloud.client.hostname}:${spring.application.name}:${spring.application.instance_id:${server.port}}}

添加了依赖就能集成Eureka Client,主类上添加 @EnableDiscoveryClient 注解不是必须。

启动程序后,进入Eureka Server页面即可看到注册的服务

一些知识点(建议掌握)

  1. Eureka Client在注册服务时,提供包括hostname,IP地址, port, health indicator url,status page, home page 等在内的meta-data,其它客户端可通过这些信息来直接与服务进行交互,我们也可以通过 eureka.instance.metadataMap 来添加自定义的meta-data,供客户端访问。

  2. Eureka Server通过接收Eureka Client的心跳消息来判断服务实例是否存活,如果某一个实例的心跳在特定时间(可配置)内没收到,则将其从注册表中移除。心跳默认间隔为30s,一个服务被其它客户端发现,可能需要经过3次心跳,这也是有时候服务注册比较慢的原因。可通过eureka.instance.leaseRenewalIntervalInSeconds配置,但生产环境建议最好保持默认。

  3. Eureka Client默认不会传播当前应用的健康检查状态,一旦注册成功,只要心跳存在,Eureka总是认为应用处于UP状态。可以启用Eureka的健康检查,将状态传播给Eureka,其它应用只会将请求发给UP状态的服务实例 eureka.client.healthcheck.enabled=true。注意这个配置只能配置在application.yml中,配置在bootstrap.yml中可能导致注册服务时,服务以状态为UNKOWN进行注册。

  4. Eureka Server是没有后端存储的,服务实例需要通过心跳来更新注册信息,注册信息存于内存中,Eureka Client也有一个基于内存的缓存,不需要每次请求服务都要访问注册中心获取服务地址信息。

  5. Eureka的自我保护机制:Eureka Server在短时间内丢失比较多的客户端时,会进入自我保护模式,在该模式下,Eureka Server即使发现服务实例已经不再发送心跳了,也不会从服务注册表中删除。这样,当发生网络故障时,服务注册信息仍然存于Eureka中,当网络故障恢复后,会自动退出自我保护模式。自我保护模式是一种应对网络异常的安全保护机制。相关配置: eureka.server.renewal-percent-threshold, 触发自我保护机制的阈值,默认为0.85; eureka.server.enable-self-preservation, 自我保护开启,默认为true,如果设置为false,则关闭客户端程序后,可直观地从Eureka Server的页面发现服务实例被注销删除了。

本文示例代码


    认真生活,快乐分享

欢迎关注公众号:空山新雨的技术空间

有道词典

<dependency>
...

详细X

  <依赖>
  < groupId > org.springframework.cloud < / groupId >
  < artifactId > spring-cloud-starter-netflix-eureka-server < / artifactId >
  < / >的依赖

Spring Cloud(一):服务注册中心Eureka的更多相关文章

  1. spring cloud(二)服务(注册)中心Eureka

    Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现.也是springcloud体系中最重要最核心的组 ...

  2. 如何优化Spring Cloud微服务注册中心架构?

    作者: 石杉的架构笔记 1.再回顾:什么是服务注册中心? 先回顾一下什么叫做服务注册中心? 顾名思义,假设你有一个分布式系统,里面包含了多个服务,部署在不同的机器上,然后这些不同机器上的服务之间要互相 ...

  3. Spring Cloud之服务注册中心搭建Eureka Server服务注册中⼼

    Spring Cloud并不与Spring MVC类似是一个开源框架,而是一组解决问题的规范(个人理解).解决哪些问题呢?如下: 1)服务管理:⾃动注册与发现.状态监管 2)服务负载均衡 3)熔断 4 ...

  4. 使用Spring Cloud搭建服务注册中心

    我们在之前的博客中已经介绍过阿里的分布式服务框架dubbo[Linux上安装Zookeeper以及一些注意事项][一个简单的案例带你入门Dubbo分布式框架],但是小伙伴们应该也看到了,阿里的dubb ...

  5. spring cloud(服务注册中心及服务提供者——初学一)

    Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现.也是springcloud体系中最重要最核心的组 ...

  6. Spring Cloud 之服务注册中心高可用

    服务注册中心高可用 服务注册中心 eureka-server 高可用实施 版本 Spring Boot 版本 # Spring Boot 版本: <parent> <groupId& ...

  7. spring cloud (一) 服务注册中心 Eueka

    1 pom.xml 添加依赖包 <dependency> <groupId>org.springframework.cloud</groupId> <arti ...

  8. spring cloud 服务注册中心eureka高可用集群搭建

    spring cloud 服务注册中心eureka高可用集群搭建 一,准备工作 eureka可以类比zookeeper,本文用三台机器搭建集群,也就是说要启动三个eureka注册中心 1 本文三台eu ...

  9. 孰能巧用 Spring Cloud 服务注册中心Eureka

    Eureka介绍 在Spring Cloud Netflix 整合技术栈中,Eureka既可以作为服务注册中心也可以用于服务发现对整个微服务架构起着最核心的整合作用. Eureka是基于REST(Re ...

  10. spring Cloud服务注册中心Eureka集群

    spring Cloud服务注册中心Eureka集群配置: 在application.yml文件加以下配置: server: port: 8761 tomcat: uri-encoding: UTF- ...

随机推荐

  1. JS正则验证两位小数,验证数字最简单正则表达式大全

    <h3>输入完按回车后即可验证!</h3> 正整数: <input type="text" size="20" onkeydown ...

  2. 深入理解String、StringBuffer、StringBuilder(转)

    文章系转载,非原创,原地址: http://www.cnblogs.com/dolphin0520/p/3778589.html 相信String这个类是Java中使用得最频繁的类之一,并且又是各大公 ...

  3. JPA一对多循环引用的解决&&JackSon无限递归问题

    说是解决,其实不是很完美的解决的,写出来只是想记录一下这个问题或者看一下有没有哪位仁兄会的,能否知道一二. 下面说说出现问题: 问题是这样的,当我查询一个一对多的实体的时候,工具直接就爆了,差不多我就 ...

  4. 2019-11-6-Roslyn-how-to-use-WriteLinesToFile-to-write-the-semicolons-to-file

    title author date CreateTime categories Roslyn how to use WriteLinesToFile to write the semicolons t ...

  5. 2018-8-10-VisualStudio-合并代码文件

    title author date CreateTime categories VisualStudio 合并代码文件 lindexi 2018-08-10 19:16:52 +0800 2018-2 ...

  6. linux下svn清除非版本控制文件的方法

    使用svn status命令,文件名前面显示问好的就是非版本控制的文件

  7. 「THUPC 2019」不等式 / inequality

    https://loj.ac/problem/6620 高中数学好题.. |kx+b|的函数图像很直观,直接考虑函数图像: 一定只有一段极小值点! 这个点就是最小值了 特点:斜率为0! 而且发现,如果 ...

  8. java Io流的应用

                                                                         标准输入输出流 1.1标准输入流 源数据源是标准输入设备(键盘 ...

  9. Codeforces Round #561 (Div. 2)

    C. A Tale of Two Lands 题意: 给出 n 个数,问有多少点对(x,y)满足 |x-y| ≤ |x|,|y| ≤ |x+y|: (x,y) 和 (y,x) 表示一种答案: 题解: ...

  10. Linux 旗标实现

    Linux 内核提供了一个遵守上面语义的旗标实现, 尽管术语有些不同. 为使用旗标, 内核 代码必须包含 <asm/semaphore.h>. 相关的类型是 struct semaphor ...