当前位置:   article > 正文

SpringCloud Eureka (Netflix)_spring-cloud-starter-netflix-eureka-client finch

spring-cloud-starter-netflix-eureka-client finch

简介

Euraka 用于服务注册和发现,是Netflix中的一个开源框架。它和 zookeeperConsul一样,都是用于服务注册管理和服务依赖管理。

Euraka 遵循着CAP理论中的A(可用性) P(分区容错性)。

Eureka中分为eureka servereureka client。其中eureka server是作为服务的注册与发现中心。eureka client既可以作为服务的生产者,又可以作为服务的消费者。 

注册中心能解决什么样的问题:

  • 服务注册后,如何被及时发现
  • 服务宕机后,如何及时下线
  • 服务如何有效的水平扩展
  • 服务发现时,如何进行路由
  • 服务异常时,如何进行降级
  • 注册中心如何实现高可用

常见注册中心对比


 eureka 服务消费实现方式:

discoveryClient:通过元数据获取服务信息

loadBalancerClient:Ribbon 的负载均衡器

@LoadBalanced:通过注解开启  Ribbon 的负载均衡器


Eureka自我保护机制

通过配置 eureka.server.enable-self-preservation 来true打开false禁用自我保护机制,默认打开状态,建议生产环境打开此配置。


eureka server 项目构建

  • pom文件引入Eureka server 端依赖。
  • 启动类加入@EnableEurekaServer注解,表示此项目作为Eureka server 端服务。
  • yaml文件配置

非高可用示例

pom文件引入Eureka server 端依赖(SpringCloud的依赖版本号管理通常放到父项目中)

  1. <!--eureka-server-->
  2. <dependency>
  3. <groupId>org.springframework.cloud</groupId>
  4. <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
  5. </dependency>
  1. <!--提供SpringCloud的依赖版本号管理-->
  2. <dependencyManagement>
  3. <dependencies>
  4. <dependency>
  5. <groupId>org.springframework.cloud</groupId>
  6. <artifactId>spring-cloud-dependencies</artifactId>
  7. <version>${spring.cloud-version}</version>
  8. <type>pom</type>
  9. <scope>import</scope>
  10. </dependency>
  11. </dependencies>

 启动类加入@EnableEurekaServer注解,表示此项目作为Eureka server 端服务

  1. @SpringBootApplication
  2. @EnableEurekaServer
  3. public class EurekaServer1Application {
  4. public static void main(String[] args) {
  5. SpringApplication.run(EurekaServer1Application.class, args);
  6. }
  7. }

yaml文件配置:

  1. server:
  2. port: 8761 #端口号
  3. eureka:
  4. server:
  5. enable-self-preservation: false # true 开启自我保护,false 关闭自我保护,默认开启
  6. instance:
  7. hostname: ludb-1 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取
  8. client:
  9. registerWithEureka: false #是否将自己注册到注册中心,默认True
  10. fetchRegistry: false #是否从注册中心获取注册信息,默认为True
  11. serviceUrl:
  12. defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #注册中心对外暴露的注册地址
  13. spring:
  14. application:
  15. name: ludb-server-1 #应用名称

注意 :

  • 非高可用的 eureka server 如果将自己注册到注册中心会报错(因为他自己就是注册中心)。
  • 非高可用的 eureka server 通常不需要从注册中心获取注册信息。

 高可用示例

新增另一个eureka server 项目,与之前单台注册中心仅配置不同

eureka server (V1)

  1. server:
  2. port: 8761 #端口号
  3. eureka:
  4. instance:
  5. hostname: ludb-1 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取
  6. prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
  7. instance-id: ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口
  8. client:
  9. # 设置服务注册中心地址,指向另一个注册中心,以实现高可用
  10. serviceUrl:
  11. defaultZone: http://localhost:8762/eureka/
  12. # registerWithEureka: false #是否将自己注册到注册中心,默认True
  13. # fetchRegistry: false #是否从注册中心获取注册信息,默认为True
  14. # serviceUrl:
  15. # defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #注册中心对外暴露的注册地址
  16. spring:
  17. application:
  18. name: ludb-server #应用名称

eureka server (V2)

  1. server:
  2. port: 8762 #端口号
  3. eureka:
  4. instance:
  5. hostname: ludb-2 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取
  6. prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
  7. instance-id: ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口
  8. client:
  9. # 设置服务注册中心地址,指向另一个注册中心,以实现高可用
  10. serviceUrl:
  11. defaultZone: http://localhost:8761/eureka/
  12. # registerWithEureka: false #是否将自己注册到注册中心,默认True
  13. # fetchRegistry: false #是否从注册中心获取注册信息,默认为True
  14. # serviceUrl:
  15. # defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #注册中心对外暴露的注册地址
  16. spring:
  17. application:
  18. name: ludb-server #应用名称

注意: 

  • 两台 eureka server 为相互注册。
  • prefer-ip-address 和 instance-id 的配置是为了eureka server 界面可以展示出IP+端口
  • 两台 eureka server 设置为将自己注册到注册中心,并且从注册中心获取注册信息(默认就是如此所以注释掉了)。
  • 应用名称需要一样。
  • eureka.client.serviceUrl.defaultZone 和 eureka.client.service-url.defaultZone 应该是没有区别的。

效果(加prefer-ip-address 和 instance-id之前):

 效果(加prefer-ip-address 和 instance-id之后):


eureka client 项目构建

  • pom文件引入Eureka client 端依赖。
  • 启动类加入 @EnableEurekaClient 注解,表示此项目作为Eureka Client端服务。
  • yaml文件配置

eureka client 项目构建

application.yaml

  1. server:
  2. port: 8081
  3. eureka:
  4. instance:
  5. prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
  6. instance-id: ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口
  7. client:
  8. # 设置服务注册中心地址【向注册中心集群注册(注册两台是为了防止第一台宕机还可以挂在第2台上)】
  9. service-url:
  10. defaultZone: http://localhost:8761/eureka/,http://localhost:8762/eureka/
  11. registry-fetch-interval-seconds: 10 #表示10秒拉取一次服务注册信息,默认30
  12. register-with-eureka: true #是否将自己注册到注册中心,默认true
  13. spring:
  14. application:
  15. name: ludb-client-1 #应用名称

 pom.xml 引入client端的pom文件

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  4. </dependency>

启动类

  1. @SpringBootApplication
  2. //如果配置文件配置了注册中心相关配置,则默认开启注册中心注解(@EnableEurekaClient)
  3. @EnableEurekaClient
  4. public class EurekaClient1Application {
  5. public static void main(String[] args) {
  6. SpringApplication.run(EurekaClient1Application.class, args);
  7. }
  8. }

注意:

  • 启动类 如果配置文件配置了注册中心相关配置,则默认开启注册中心注解
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/1000176
推荐阅读
相关标签
  

闽ICP备14008679号