這篇文章主要介紹“怎么通過docker和docker-compose實現(xiàn)eureka高可用”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強(qiáng),希望這篇“怎么通過docker和docker-compose實現(xiàn)eureka高可用”文章能幫助大家解決問題。
創(chuàng)新互聯(lián)于2013年開始,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目成都網(wǎng)站建設(shè)、網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元周村做網(wǎng)站,已為上家服務(wù),為周村各地企業(yè)和個人服務(wù),聯(lián)系電話:028-86922220
1. eureka server項目目錄結(jié)構(gòu):

2. eureka 配置文件配置:
server:
port: 8900
spring:
application:
name: eureka-server
profiles:
active: dev
management:
security:
enabled: false
health:
rabbit:
enabled: false
---
spring:
profiles: dev
eureka:
client:
serviceurl:
defaultzone: http://localhost:${server.port}/eureka/
register-with-eureka: false
fetch-registry: false
instance:
hostname: localhost
prefer-ip-address: true
---
spring:
profiles: test_ha_1
eureka:
client:
serviceurl:
defaultzone: http://eurekaserver2:${server.port}/eureka/
instance:
hostname: eurekaserver1
# prefer-ip-address: true 該配置為true表示注冊到eureka上的是ip,如果這樣的化,eureka服務(wù)器就不能通過服務(wù)器發(fā)現(xiàn)replicas。
# 故如果想通過docker實現(xiàn)eureka高可用,該配置最好使用默認(rèn)值(false)
# 此處配置為true且實現(xiàn)高可用也不是沒有辦法,就是每個eureka服務(wù)需映射到docker環(huán)境外,且知道ip。
---
spring:
profiles: test_ha_2
eureka:
client:
serviceurl:
defaultzone: http://eurekaserver1:${server.port}/eureka/
instance:
hostname: eurekaserver2
# prefer-ip-address: true3. docker maven插件配置:
<build>
<plugins>
<plugin>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-maven-plugin</artifactid>
</plugin>
<plugin>
<groupid>com.spotify</groupid>
<artifactid>docker-maven-plugin</artifactid>
<version>0.4.13</version>
<configuration>
<imagename>${docker.image.prefix}/${project.artifactid}:${project.version}</imagename>
<dockerdirectory>src/main/docker</dockerdirectory>
<forcetags>true</forcetags>
<resources>
<resource>
<targetpath>/</targetpath>
<directory>${project.build.directory}</directory>
</resource>
</resources>
</configuration>
<!--<groupid>com.spotify</groupid>
<artifactid>docker-maven-plugin</artifactid>
<version>0.4.13</version>
<configuration>
<imagename>itmuch/${project.artifactid}:${project.version}</imagename>
<forcetags>true</forcetags>
<baseimage>java</baseimage>
<entrypoint>["java", "-jar", "/${project.build.finalname}.jar"]</entrypoint>
<resources>
<resource>
<targetpath>/</targetpath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalname}.jar</include>
</resource>
</resources>
</configuration>-->
</plugin>
</plugins>
</build>4. docker file 文件內(nèi)容:
from java:8 add eureka-server-1.0.0.jar eurekaserver.jar entrypoint ["java","-djava.security.egd=file:/dev/./urandom","-jar","/eurekaserver.jar"]
5. 生成 eureka server 鏡像:
通過執(zhí)行 mvn clean package docker:build 命令,生成eurekaserver鏡像,如下:

6. 通過docker-compose 編排:
version: '2' services: eurekaserver1: image: raynspace/eureka-server:1.0.0 ports: - "7900:8900" environment: - spring.profiles.active=test_ha_1 eurekaserver2: image: raynspace/eureka-server:1.0.0 #hostname: eurekaserver2 ports: - "7800:8900" environment: - spring.profiles.active=test_ha_2
7. 跳轉(zhuǎn)至項目目錄下,執(zhí)行docker-compose up 命令,自動生成eureka server 兩個容器:

8. 由于已經(jīng)把eureka 端口映射出來,所以本地通過端口訪問eureka,查看eureka 服務(wù)狀態(tài):

通過上圖可知,在registered-replicas和available-replicas兩項均能看見另外一個eureka服務(wù),至此eureka 集群搭建完成。
關(guān)于“怎么通過docker和docker-compose實現(xiàn)eureka高可用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。
新聞標(biāo)題:怎么通過docker和docker-compose實現(xiàn)eureka高可用
文章出自:http://www.chinadenli.net/article20/iiejjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、服務(wù)器托管、虛擬主機(jī)、網(wǎng)頁設(shè)計公司、建站公司、小程序開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)