springCloud Eureka注冊中心集群搭建
- 因為注冊中心很重要碰声,屬于服務(wù)的入口點撩笆,所以絕對不能是單點的,需要搭建集群滑潘,本例中使用三個Eureka節(jié)點組成為集群;(使用Idea模擬啟動三個節(jié)點)
- Eureka控制臺參數(shù)說明
- 環(huán)境說明:java8, springboot-2.0.1;
- 首先在idea中創(chuàng)建一個springboot項目名稱為:
springcloud-eureka-service
- pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>eureka</groupId>
<artifactId>springcloud-eureka-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-eureka-service</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<!-- spring-cloud-dependencies依賴管理器锨咙,對cloud的依賴管理 -->
<dependencyManagement>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.M7</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!-- 注冊中心服務(wù)依賴 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
<!-- 必須有該配置众羡,否則依賴會出問題 -->
<repositories>
<!-- 從指定庫中獲取依賴
注意:要修改maven的setttings.xml 如下:
<mirrorOf>*,!spring-milestones</mirrorOf>
表示maven除了spring-milestones以外全部從settings配置的倉庫中獲取依賴-->
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/libs-milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
- 項目啟動文件:
SpringcloudEurekaServiceApplication
:
package eureka.springcloudeurekaservice;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
// @EnableEurekaServer 代表啟動Eureka注冊中心服務(wù)端
@EnableEurekaServer
public class SpringcloudEurekaServiceApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudEurekaServiceApplication.class, args);
}
}
-
application.yml
配置
###服務(wù)別名--該服務(wù)注冊到服務(wù)中心的名稱
spring:
application:
name: app-eureka
profiles:
active: server1
-
application-server1.yml
配置
### Eureka注冊中心1
server:
port: 7100
###服務(wù)別名--該服務(wù)注冊到服務(wù)中心的名稱
spring:
application:
name: eureka-server
eureka:
instance:
### 注冊中心ip地址
hostname: eureka-server1
#訪問路徑可以顯示ip地址
#prefer-ip-address: true
#自定義入駐別名
#instance-id: euserver1:7100
client:
serviceUrl:
###注冊中心地址
#defaultZone: http://${eureka.instance.hostname}:8100/eureka/,http://${eureka.instance.hostname}:9100/eureka/
defaultZone: http://eureka-server2:8100/eureka/,http://eureka-server3:9100/eureka/
###要將自己注冊到注冊中心
register-with-eureka: true
### 要去檢索服務(wù)信息
fetch-registry: true
-
application-server2.yml
配置
### Eureka注冊中心2
server:
port: 8100
###服務(wù)別名--該服務(wù)注冊到服務(wù)中心的名稱
spring:
application:
name: eureka-server
eureka:
instance:
### 注冊中心ip地址
hostname: eureka-server2
client:
serviceUrl:
###注冊中心地址
defaultZone: http://eureka-server1:7100/eureka/,http://eureka-server3:9100/eureka/
###要將自己注冊到注冊中心
register-with-eureka: true
### 要去檢索服務(wù)信息
fetch-registry: true
-
application-server3.yml
配置
-
### Eureka注冊中心3
server:
port: 9100
###服務(wù)別名--該服務(wù)注冊到服務(wù)中心的名稱
spring:
application:
name: eureka-server
eureka:
instance:
### 注冊中心ip地址
hostname: eureka-server3
client:
serviceUrl:
###注冊中心地址
defaultZone: http://eureka-server1:7100/eureka/,http://eureka-server2:8100/eureka/
###要將自己注冊到注冊中心
register-with-eureka: true
### 要去檢索服務(wù)信息
fetch-registry: true
- 配置host
127.0.0.1 eureka-server1
127.0.0.1 eureka-server2
127.0.0.1 eureka-server3
-
配置idea,創(chuàng)建加載三個配置文件的入口
以同樣的方式分別創(chuàng)建三個服務(wù)的激動入口
server1
,server2
,server3
;分別啟動三個服務(wù)后
-
訪問集群節(jié)點一:http://eureka-server1:7100/,效果如下:
-
訪問集群節(jié)點二:http://eureka-server2:8100/
-
訪問集群節(jié)點三:
代碼地址:https://github.com/liangxifeng833/springcloud/tree/master/eureka