SpringCloud教程 | 八.構建高可用註冊中心
阿新 • • 發佈:2019-01-24
簡介
SpringCloud教程 | 一.服務的註冊與發現(Eureka)主要演示瞭如何構建和啟動服務註冊中心Eureka Server,以及如何將服務註冊到Eureka Server中,但是在之前的示例中,這個服務註冊中心是單點的,顯然這並不適合應用於線上生產環境,那麼下面在前文的基礎上,我們來看看該如何構建高可用的Eureka Server叢集。
Eureka Server除了單點執行之外,還可以通過執行多個例項,並進行互相註冊的方式來實現高可用的部署,所以我們只需要將Eureke Server配置其他可用的serviceUrl就能實現高可用部署。
下面以spring-cloud-eureka專案為基礎,構建高可用的註冊中心
1.專案結構如下:
2.pom.xml(未改變)如下:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <spring-cloud.version>Edgware.RELEASE</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
3.建立application-peer1.properties,內容如下
spring.application.name=eureka-server
server.port=1001
eureka.instance.hostname=peer1
eureka.client.serviceUrl.defaultZone=http://peer2:1002/eureka
4.建立application-peer2.properties,內容如下
spring.application.name=eureka-server server.port=1002 eureka.instance.hostname=peer2 eureka.client.serviceUrl.defaultZone=http://peer1:1001/eureka
5.修改hosts檔案
windows系統目錄為:C:\Windows\System32\drivers\etc
Linux系統目錄為:/etc/hosts
127.0.0.1 peer1
127.0.0.1 peer2
6.啟動eureka-server
將專案打成jar包,通過cmd命令執行如下命令
java -jar eureka-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1
java -jar eureka-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2
7.執行eureka-client,詳情檢視SpringCloud教程 | 一.服務的註冊與發現(Eureka)
eureka-client的配置檔案application.properties如下【注意:這邊只填寫了一個註冊中心】:
8.分別檢視兩個註冊中心
當把peer1(localhost:1001)關掉之後,peer2依舊能夠作為eureka-client的註冊中心,說明註冊中心的高可用生效!!!