国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務(wù)器 > Web服務(wù)器 > 正文

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

2024-09-01 13:55:37
字體:
供稿:網(wǎng)友

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

1. eureka server項目目錄結(jié)構(gòu):

docker,docker-compose,eureka,高可用

2. eureka 配置文件配置:

server: port: 8900spring: application:  name: eureka-server profiles:  active: devmanagement: security:  enabled: false health:  rabbit:   enabled: false---spring: profiles: deveureka: 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_1eureka: 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_2eureka: 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:8ADD eureka-server-1.0.0.jar eurekaserver.jarENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/eurekaserver.jar"]

5. 生成 eureka server 鏡像:

通過執(zhí)行 mvn clean package docker:build 命令,生成eurekaserver鏡像,如下:

docker,docker-compose,eureka,高可用

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 兩個容器:

docker,docker-compose,eureka,高可用

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

docker,docker-compose,eureka,高可用

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到服務(wù)器教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 阜康市| 沁阳市| 辉南县| 玉树县| 苍山县| 南康市| 潼南县| 五指山市| 兖州市| 富川| 广丰县| 汉寿县| 新田县| 兴山县| 巴南区| 涞水县| 伊通| 苗栗市| 绿春县| 义马市| 贡觉县| 铁岭市| 三亚市| 大城县| 竹山县| 吐鲁番市| 高青县| 闽侯县| 大方县| 临潭县| 双江| 怀仁县| 孟村| 贺州市| 长乐市| 巴塘县| 江城| 无极县| 永安市| 扎鲁特旗| 喜德县|