来自知乎,版权归recole所有,转载请自觉标明原文出处
IDEA同一服务开多个实例的方法 - 知乎 (zhihu.com)https://zhuanlan.zhihu.com/p/393941974
可以通过IDEA
的端口参数设置或application配置文件两种方法来实现同一服务开启多个实例的效果。
一、通过端口参数开启多个实例
首先注释掉application.properties
或application.yml
文件里的端口号。
1、进入IDEA
的运行设置,选择“Edit configurations...”
2、通过VM options
增加第1个端口
-Dserver.port=8001
3、点击左上方的复制
图标增加多个端口
4、 配置一个批量启动
点击“+”图标把多个要同时启动的项目添加进来即可
5、运行批量启动:选中刚配置好的批量启动够稳,然后点击运行
按钮。
二、通过application.yml
配置文件开启(application.properties同理)
首先注释掉application.properties或application.yml文件里的端口号。
1、在resources
目录添加以下三个文件
application-peer1.yml 文件如下(端口号7001)
server:
port: 7001
#Eureka配置
eureka:
instance:
hostname: eureka1.cn #eureka服务端的实例名称
client:
register-with-eureka: false #表示是否向eureka注册中心注册自己
fetch-registry: false # 如果fetch-registry为false,表示自己为注册中心
service-url: #监控页面
#单机:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #默认8761端口
#集群(关联):
#defaultZone: http://eureka2.cn:7002/eureka,http://eureka3.cn:7003/eureka
defaultZone: http://eureka2.cn:7002/eureka,http://eureka3.cn:7003/eureka
application-peer2.yml 文件如下(端口号7002)
server:
port: 7002
#Eureka配置
eureka:
instance:
hostname: eureka1.cn #eureka服务端的实例名称
client:
register-with-eureka: false #表示是否向eureka注册中心注册自己
fetch-registry: false # 如果fetch-registry为false,表示自己为注册中心
service-url: #监控页面
#单机:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #默认8761端口
#集群(关联):
#defaultZone: http://eureka2.cn:7002/eureka,http://eureka3.cn:7003/eureka
defaultZone: http://eureka1.cn:7001/eureka,http://eureka3.cn:7003/eureka
application-peer3.yml 文件如下(端口号7003)
server:
port: 7003
#Eureka配置
eureka:
instance:
hostname: eureka1.cn #eureka服务端的实例名称
client:
register-with-eureka: false #表示是否向eureka注册中心注册自己
fetch-registry: false # 如果fetch-registry为false,表示自己为注册中心
service-url: #监控页面
#单机:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #默认8761端口
#集群(关联):
#defaultZone: http://eureka2.cn:7002/eureka,http://eureka3.cn:7003/eureka
defaultZone: http://eureka1.cn:7001/eureka,http://eureka2.cn:7002/eureka
2、设置启动项
2.1、进入IDEA的运行设置,选择“Edit configurations...”
配置要对应的application-peer.yml
文件
2.2 配置多个,选中模块,然后点击左上方的复制
按钮,然后按参考以上2.1配置即可。
批量启动服务请参考以上通过端口参数开启多个实例
的方法。