Eureka高可用配置

一,搭建eureka服务
1,在eureka服务端模块引入相关坐标

 <!--eureka服务端坐标-->
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

2,yml文件中配置eureka

server:
  port: ${port:9000}   #${port:9000}默认从虚拟机参数中获取port的值
  servlet:
    context-path:
eureka:
  instance:
    hostname: 127.0.0.1  #配置本机的主机名
  client:
   # register-with-eureka: false #是否将自己注册到服务 默认为true
   # fetch-registry: false  #是否从服务中获取自己的注册信息 默认为true
    service-url:     
   	  #注册到eurek服务的地址   
      defaultZone: ${defaultZone:http://127.0.0.1:9000/eureka/}   

注:
将自己的地址注册到eureka服务。
defaultZone: ${defaultZone:http://127.0.0.1:9000/eureka/} 默认从虚拟机参数中获取defaultZone的值,如果获取不到将取http://127.0.0.1:9000/eureka/作为defaultZone的值。
port: ${port:9000}同理。

3,配置多个eureka服务,虚拟机参数配置如下
eureka端口为9000:

在这里插入图片描述
eureka端口为8000:
在这里插入图片描述

这两个服务之间相互注册

二,搭建服务提供者模块,将其分别注册到eureka服务中
1,导入eureka客户端坐标

<!--eureka客户端坐标-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

2,配置文件如下:

eureka:
  #  instanc中的配置是让该服务使用IP注册到注册中心,而不是hostname
  instance:
    prefer-ip-address: true   #使用地址注册
    ip-address: 127.0.0.1   #当前服务的ip地址
    #续约间隔,默认30秒
    lease-renewal-interval-in-seconds: 5   #每间隔5秒向eureka服务发送心跳
    #服务失效时间,默认90秒
    lease-expiration-duration-in-seconds: 5
  client:
    service-url:
      defaultZone: http://127.0.0.1:9000/eureka/,http://127.0.0.1:8000/eureka/  #注册到Eureka服务的地址

三,搭建eureka服务消费者模块,将其注册到eureka服务中
1,引入相关坐标

 <!--eureka客户端坐标-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

2,yml配置文件如下

eureka:
  #  instanc中的配置是让该服务使用IP注册到注册中心,而不是hostname
  instance:
    prefer-ip-address: true   #使用地址注册
    ip-address: 127.0.0.1
  client:
    service-url:
      defaultZone: http://127.0.0.1:9000/eureka/,http://127.0.0.1:8000/eureka/  #注册到多个eureka服务地址中间用逗号隔开
    registry-fetch-interval-seconds: 10  #获取服务提供者列表的时隔

这样就实现了eureka高可用配置。

!!!!!!!!!!这里总结一下我搭建环境时踩到的坑!!!!!!!!!
当我搭建完环境后服务提供者和服务消费者模块无法启动
遇到如下问题:
在这里插入图片描述
由于模块中没有导入springboot启动jar包导致项目无法启动

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.1.6.RELEASE</version>
        </dependency>

而eureka服务模块中导入的坐标包含springboot的启动坐标,所以不需要到如此启动包。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值