一,搭建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的启动坐标,所以不需要到如此启动包。