首页 > 其他分享 >springcloud之使用eureka例子&实现高可用

springcloud之使用eureka例子&实现高可用

时间:2022-11-30 18:34:18浏览次数:37  
标签:service springcloud Eureka 例子 注册 eureka server true


1-准备2(.../n)个EurekaServer,需要相互注册

  •     1号server:9000

    首先,将eureka_server子模块的resources中的application.yml修改如下

server:
port: 9000 #端口
#配置eureka server
eureka:
client:
# register-with-eureka: false #是否将自己注册到注册中心
# fetch-registry: false #是否从eureka中获取注册信息
service-url: #配置暴露给Eureka Client的请求地址
defaultZone: http://127.0.0.1:8000/eureka/

运行eureka_server子模块的启动类EurekaServerApplication

  •     2号server:8000
  • 继续修改application.yml
#指定应用名称
spring:
application:
name: eureka-server

server:
port: 8000 #端口
#配置eureka server
eureka:
client:
# register-with-eureka: false #是否将自己注册到注册中心
# fetch-registry: false #是否从eureka中获取注册信息
service-url: #配置暴露给Eureka Client的请求地址
defaultZone: http://127.0.0.1:9000/eureka/

显示IDEA Run dashboard功能

在Help---Edit Custom VM Options中添加了 -Dide.run.dashboard = true 键值对;并重新启动IntelliJ IDEA!

springcloud之使用eureka例子&实现高可用_ip地址

再次运行eureka_server子模块的启动类EurekaServerApplication

springcloud之使用eureka例子&实现高可用_mysql_02

springcloud之使用eureka例子&实现高可用_ip地址_03

此时

springcloud之使用eureka例子&实现高可用_mysql_04

springcloud之使用eureka例子&实现高可用_spring_05

springcloud之使用eureka例子&实现高可用_ip地址_06

2-需要将微服务注册到两个EurekaServer上

对product_service子模块,修改application.yml  defaultZone

server:
port: 9001
spring:
application:
name: service-product
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false
username: root
password: 123456
jpa:
database: MySQL
show-sql: true
open-in-view: true
#配置Eureka
eureka:
client:
service-url:
defaultZone: http://localhost:9000/eureka/,http://localhost:8000/eureka/ #有多个eureka server就注册多次,多个eureka server之间用,隔开
instance:
prefer-ip-address: true #使用ip地址注册

对order_service子模块,修改application.yml  defaultZone

server:
port: 9002
spring:
application:
name: service-order
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false
username: root
password: 123456
jpa:
database: MySQL
show-sql: true
open-in-view: true
#配置Eureka
eureka:
client:
service-url:
defaultZone: http://localhost:9000/eureka/,http://localhost:8000/eureka/
instance:
prefer-ip-address: true #使用ip地址注册

此时实现了高可用

springcloud之使用eureka例子&实现高可用_spring_07

springcloud之使用eureka例子&实现高可用_spring_08

断掉一个时,

springcloud之使用eureka例子&实现高可用_mysql_09

仍可访问

springcloud之使用eureka例子&实现高可用_spring_10

细节问题

在控制台显示服务IP

在服务提供者,product_service的application.yml中添加instance-id通过eureka.instance.instance-id配置控制台显示服务ip

#配置Eureka
eureka:
client:
service-url:
defaultZone: http://localhost:9000/eureka/,http://localhost:8000/eureka/ #有多个eureka server就注册多次,多个eureka server之间用,隔开
instance:
prefer-ip-address: true #使用ip地址注册
instance-id: ${spring.cloud.client.ip-address}:${server.port} #向注册中心中注册服务id

 此时

springcloud之使用eureka例子&实现高可用_spring_11

Eureka的服务剔除问题

springcloud之使用eureka例子&实现高可用_mysql_12

 在服务的提供者product_service子模块中,设置心跳间隔,设置续约到期时间lease-renewal-interval-in-seconds,  lease-expiration-duration-in-seconds

修改其application.yml

#配置Eureka
eureka:
client:
service-url:
defaultZone: http://localhost:9000/eureka/ #有多个eureka server就注册多次,多个eureka server之间用,隔开
instance:
prefer-ip-address: true #使用ip地址注册
instance-id: ${spring.cloud.client.ip-address}:${server.port} #向注册中心中注册服务id
lease-renewal-interval-in-seconds: 5 #设置心跳间隔
lease-expiration-duration-in-seconds: 10 #设置续约到期时间

关闭Eureka的自我保护机制和设置剔除服务间隔(不推荐)

Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 会将这些实例保护起来,让这些实例不会过期,但是在保护期内如果服务刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,此时会调用失败,对于这个问题需要服务消费者端要有一些容错机制,如重试,断路器等。

我们在单机测试的时候很容易满足心跳失败比例在 15 分钟之内低于 85%,这个时候就会触发 Eureka 的保护机制,一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了,此时我们可以使用​​eureka.server.enable-self-preservation=false​​来关闭保护机制,这样可以确保注册中心中不可用的实例被及时的剔除(不推荐)。

解决方式有三种:

  • 关闭自我保护模式(​​eureka.server.enable-self-preservation​​​设为​​false​​),不推荐
  • 降低​​renewalPercentThreshold​​​的比例(​​eureka.server.renewal-percent-threshold​​​设置为​​0.5​​​以下,比如​​0.49​​),不推荐
  • 部署多个 Eureka Server 并开启其客户端行为(​​eureka.client.register-with-eureka​​​不要设为​​false​​​,默认为​​true​​),推荐

Eureka 的自我保护模式是有意义的,该模式被激活后,它不会从注册列表中剔除因长时间没收到心跳导致租期过期的服务,而是等待修复,直到心跳恢复正常之后,它自动退出自我保护模式。这种模式旨在避免因网络分区故障导致服务不可用的问题。例如,两个客户端实例 C1 和 C2 的连通性是良好的,但是由于网络故障,C2 未能及时向 Eureka 发送心跳续约,这时候 Eureka 不能简单的将 C2 从注册表中剔除。因为如果剔除了,C1 就无法从 Eureka 服务器中获取 C2 注册的服务,但是这时候 C2 服务是可用的。

在eureka_server子模块中,修改resources的application.yml

#配置eureka server
eureka:
client:
register-with-eureka: false #是否将自己注册到注册中心
fetch-registry: false #是否从eureka中获取注册信息
service-url: #配置暴露给Eureka Client的请求地址
defaultZone: http://127.0.0.1:9000/eureka/
server:
enable-self-preservation: false #关闭自我保护
eviction-interval-timer-in-ms: 4000 #剔除服务间隔 ,毫秒

 

标签:service,springcloud,Eureka,例子,注册,eureka,server,true
From: https://blog.51cto.com/u_12528551/5900119

相关文章

  • springcloud之eureka server启动原理
    /org/springframework/cloud/spring-cloud-netflix-eureka-server/2.1.0.RELEASE/spring-cloud-netflix-eureka-server-2.1.0.RELEASE.jar!/META-INF/spring.factories中 ......
  • springcloud之eureka client的启动流程
    eurekaclien向eurekaserver准备的web接口发送http请求,完成服务注册,获取...org/springframework/cloud/spring-cloud-netflix-eureka-client/2.1.0.RELEASE/spring-cloud......
  • springcloud之负载均衡策略
    Ribbon内置了多种负载均衡策略,内部负责负载均衡的顶级接口为com.netflix.loadbalanced.IRule  服务消费者,application.yml中添加#修改ribbon的负载均衡策略服务名-......
  • SpringCloud之Config分布式配置文件中心
    分布式系统面临的配置问题:微服务意味着要将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务。由于每个服务都需要必要的配置信息......
  • 枚举小例子记录
    1、创建枚举类:packagecom.atguigu.common.constant;publicclassProductConstant{publicenumAttrEnum{ATTR_TYPE_BASE(1,"基本属性"),ATTR_TYPE_SALE......
  • SpringCloud01
    SpringCloud011.认识微服务随着互联网行业的发展,对服务的要求也越来越高,服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢?1.0.学习目......
  • Mybatis更新小例子记录
    转自:https://blog.csdn.net/mikelv01/article/details/123920873//源码/***根据whereEntity条件,更新记录**@paramentity实体对象(set条件值,可以为null......
  • 搭建EurekaServer注册中心报错:Unable to start web server; nested exception is org.
    错误异常:Unabletostartwebserver;nestedexceptionisorg.springframework.boot.web.server.WebServerException:UnabletostartembeddedTomcat今天搭建springcl......
  • MybatisPlus查询小例子
    @OverridepublicPageUtilsqueryBaseAttrPage(Map<String,Object>params,LongcatelogId){QueryWrapper<AttrEntity>queryWrapper=newQueryWrapper<>();i......
  • windows下使用idea maven配置spark运行环境、运行WordCount例子以及碰到的问题
    一、安装JAVAJDK、Maven、scala这些安装都比较简单都可以去官网下载最新版本的安装包一一安装就可以了。scala官网下载地址:​​http://www.scala-lang.org/download/​​......