以下,将展示如何在服务的同一个application.yml文件中通过简易的配置实现集群的搭建.
打开provider项目的application.yml文件,
通过连字符'---'将该application.yml文件分为三段.
第二段和第三段分别为spring.profiles指定了一个值,该值表示它所在的那段内容应用在哪个Profile里.
第一段由于并未指定spring.profiles,因此这段内容会对所有Profile生效.
spring:
application:
name: springcloud-provider
security:
user:
name: shanghai #配置EurekaServer的http basic认证账号
password: 111 #配置EurekaServer的http basic认证密码
---
spring:
profiles: provider8081 #指定profiles为provider8081
server:
port: 8081
eureka:
instance:
hostname: provider8081 #当profiles为provider8081时,主机名为provider8081
prefer-ip-address: false
metadata-map:
my-data: This is my provider8081
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://${spring.security.user.name}:${spring.security.user.password}@localhost:8761/eureka/
---
spring:
profiles: provider8082 #指定profiles为provider8082
server:
port: 8082
eureka:
instance:
hostname: provider8082 #当profiles为provider8082时,主机名为provider8082
prefer-ip-address: false
metadata-map:
my-data: This is my provider8082
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://${spring.security.user.name}:${spring.security.user.password}@localhost:8761/eureka/
配置好application.yml文件后,只需要在启动的时候,通过spring.profiles.active指定特定的Profile段即可.
在Idea中配置两个不同Profile的启动类,步骤如下:
配置服务启动类指定provider8081启动:
第一步,在Idea右上角处选择Edit Configurations选项.进入启动类配置界面.
第二步,在启动类配置界面的Program arguments框中指定启动类以哪个Profile段配置启动
第三步,保存配置,启动该类
可以看出,该服务的第一个实例占用8081端口,符合Profile为provider8081的配置.
配置服务启动类指定provider8082启动:
第一步,需要创建一个springboot启动类的配置窗口
由上图操作,可得到一个空配置的springboot配置窗口.
第二步,对相关参数进行配置.
第三步,点击保存.这时Run Dashboard框中便会把刚才配置的启动类添加到框中.启动该类
可以看出,该服务的第二个实例占用8082端口,符合Profile为provider8082的配置.
为了能更加直观的看到provider服务的两个实例,可以进入eurekaServer注册中心查看.
在浏览器输入,http://localhost:8761,输入配置好的http basic账号密码进入注册中心.
进入配置中心后,便可看到provider服务已经成功注册好了两个实例.分别占用8081端口和8082端口.
现在分别试着调用一下两实例的接口,调用结果如下:
调用端口为8081的provider实例接口:
调用端口为8082的provider实例接口:
两实例接口均可成功调用,所有provider两节点健康状态均正常.一个小集群便可由此搭建起来.