Eureka Server 高可用環境需要部署兩個Eureka server,它們互相向對方注冊。如果在本機啟動兩個Eureka需要注意兩個Eureka Server的端口要設置不一樣
1、在實際使用時Eureka Server
至少部署兩台服務器,實現高可用。
2、兩台Eureka Server
互相注冊。
3、微服務需要連接兩台Eureka Server
注冊,當其中一台Eureka
死掉也不會影響服務的注冊與發現。
4、微服務會定時向Eureka server
發送心跳,報告自己的狀態。
5、微服務從注冊中心獲取服務地址以RESTful
方式發起遠程調用。
這里通過配置環境變量方式實現單項目運行多個
eureka server
1. 新建springboot
項目在maven
中引入eureka server
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
2. 配置application.xml
server:
port: ${PORT:50101}
spring:
application:
name: xc-registry
eureka:
client:
service-url:
defaultZone: ${EUREKA_SERVER:http://eureka02:50102/eureka/}
register-with-eureka: true
fetch-registry: true
server:
enable-self-preservation: false # 關閉自我保護
eviction-interval-timer-in-ms: 60000 # 每隔5秒鍾,進行一次服務列表的清理
instance:
hostname: ${EUREKA_DOMAIN:eureka01}
3. 在啟動類添加@EnableEurekaServer
配置
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
/**
* @author john
* @date 2019/12/27 - 8:59
*/
@SpringBootApplication
@EnableEurekaServer
public class XuechengRegistryApplication {
public static void main(String[] args) {
SpringApplication.run(XuechengRegistryApplication.class, args);
}
}
4. 編輯idea
運行配置
在idea
中拷貝運行配置,第一份配置中配置如下環境變量
-DPORT=50101 -DEUREKA_SERVER=http://eureka02:50102/eureka/ -DEUREKA_DOMAIN=eureka01
在第二份中配置如下環境變量
-DPORT=50102 -DEUREKA_SERVER=http://eureka01:50101/eureka/ -DEUREKA_DOMAIN=eureka02
如下圖所示
5. 修改host
文件
Eureka
組成高可用,兩個Eureka互相向對方注冊,這里需要通過域名或主機名訪問,這里我們設置兩個Eureka服
務的主機名分別為 eureka01
、eureka02
。
修改host
文件
127.0.0.1 eureka01
127.0.0.1 eureka02
5. 運行