佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 詳解通過docker和docker-compose實(shí)現(xiàn)eureka高可用

詳解通過docker和docker-compose實(shí)現(xiàn)eureka高可用

熱門標(biāo)簽:美圖手機(jī) 阿里云 網(wǎng)站建設(shè) 檢查注冊(cè)表項(xiàng) 智能手機(jī) 硅谷的囚徒呼叫中心 百度競價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 使用U盤裝系統(tǒng)

最近新項(xiàng)目有使用到springcloud 和docker,關(guān)于這兩個(gè)技術(shù)就不分別介紹了,現(xiàn)在分享一下通過docker,docker-compose實(shí)現(xiàn)eureka高可用的方案。

1. eureka server項(xiàng)目目錄結(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表示注冊(cè)到eureka上的是IP,如果這樣的化,eureka服務(wù)器就不能通過服務(wù)器發(fā)現(xiàn)Replicas。
#               故如果想通過Docker實(shí)現(xiàn)eureka高可用,該配置最好使用默認(rèn)值(false)
#               此處配置為true且實(shí)現(xiàn)高可用也不是沒有辦法,就是每個(gè)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: true

3. 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)至項(xiàng)目目錄下,執(zhí)行docker-compose up 命令,自動(dòng)生成eureka server 兩個(gè)容器:

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

通過上圖可知,在registered-replicas和available-replicas兩項(xiàng)均能看見另外一個(gè)eureka服務(wù),至此eureka 集群搭建完成。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:湘潭 懷化 山南 黃山 通遼 煙臺(tái) 賀州 湖北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解通過docker和docker-compose實(shí)現(xiàn)eureka高可用》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    遂平县| 府谷县| 宜阳县| 孟连| 钦州市| 嫩江县| 宜君县| 马鞍山市| 津市市| 玉林市| 镇原县| 徐州市| 葫芦岛市| 巫山县| 江西省| 隆化县| 天津市| 新建县| 南部县| 高清| 土默特右旗| 池州市| 监利县| 张家口市| 四川省| 谢通门县| 临江市| 环江| 尚义县| 望都县| 芮城县| 汪清县| 渑池县| 毕节市| 海丰县| 兴安盟| 屏山县| 东乌珠穆沁旗| 叙永县| 遵义市| 阜城县|