Docker-compose编排微服务顺序启动

docker-compose可以方便组合多个 docker 容器服务, 但是, 当容器服务之间存在依赖关系时, docker-compose 并不能保证服务的启动顺序。docker-compose 中的 depends_on 配置是容器的启动顺序, 并不是容器中服务的启动顺序。本章将详细叙述如何解决 docker-compose 顺序启动微服务的问题。

1.用restart:always机制

docker-compose.yml

  version:"3"

  services:

    # 指定服务名称

    #服务注册与发现中心

    simonEureka:

      image: simon/eureka-server:2.0.1-SNAPSHOT

      hostname: simonEureka

      ports:

        - "8100:8100"

    #配置中心    

    simonConfig:

      image: simon/config-server:2.0.1-SNAPSHOT

      hostname: simonConfig

      ports:

        - "8101:8101"

      depends_on:

        - simonEureka

      restart: always

    #路由网关  

    apigateway:

      image: simon/apigateway:2.0.1-SNAPSHOT

      ports:

        - "8102:8102"

      depends_on:

        - simonEureka

        - simonConfig

      restart: always

    #监控平台  

    admin:

      image: simon/admin:2.0.1-SNAPSHOT

      ports:

        - "8103:8103"

      depends_on:

        - simonEureka

        - simonConfig

      restart: always

2.用shell脚本阻止当前服务启动,直到所需依赖的服务全部启动之后再启动当前服务。

部署的微服务如下图所示

(1)shell脚本 :entrypoint.sh (镜像中必须安装netcat要么通过maven配置要么在dockefile安装netcat

#!/bin/bash

: ${SLEEP_SECOND:=2}

wait_for() {

    echo Waiting for $1 to listen on $2...

    while ! nc -z $1 $2; do echo waiting...; sleep $SLEEP_SECOND; done

}

declare DEPENDSdeclare CMD

while getopts "d:c:" argdo

    case $arg in

        d)

            DEPENDS=$OPTARG

            ;;

        c)

            CMD=$OPTARG

            ;;

        ?)

            echo "unkonw argument"

            exit 1

            ;;

    esacdone

for var in ${DEPENDS//,/}do

    host=${var%:*}

    port=${var#*:}

    wait_for $host $portdone

eval $CMD#避免执行完命令之后退出容器

tail -f /dev/null

这个脚本有2 个参数:

-d: 需要等待的服务和端口,例如:simonEureka:8080

-c: 等待的服务和端口启动之后, 自己的启动命令,例如:java -jar eureka.jar

(2)编写docker-compose.yml

version: '2'

services:

  pig-eureka:

    build:

      context: ./

      dockerfile: Dockerfile-eureka

    restart: always

    ports:

      - 1025:1025


  pig-config:

    links:

      - pig-eureka:eureka

    build:

      context: ./

      dockerfile: Dockerfile-config      

    restart: always

    ports:

      - 4001:4001    

    volumes:

      - ./entrypoint.sh:/entrypoint.sh

    environment:

      SLEEP_SECOND: 4

    tty: true

    entrypoint: /entrypoint.sh -d pig-eureka:1025 -c 'java -jar /app/pig-config.jar';


  pig-auth:

    links:

      - pig-config:config

    build:

      context: ./

      dockerfile: Dockerfile-auth

    restart: always

    ports:

      - 3000:3000

    volumes:

      - ./entrypoint.sh:/entrypoint.sh

    environment:

      SLEEP_SECOND: 25

    tty: true

    entrypoint: /entrypoint.sh -d pig-config:4001 -c 'java -jar /app/pig-auth.jar';


  pig-gateway:

    links:

      - pig-eureka:eureka

      - pig-auth:auth

    build:

      context: ./

      dockerfile: Dockerfile-gateway

    restart: always

    ports:

      - 9999:9999

    volumes:

      - ./entrypoint.sh:/entrypoint.sh

    environment:

      SLEEP_SECOND: 26

    tty: true

entrypoint: /entrypoint.sh -d pig-auth:3000 -c 'java -jar  /app/pig-gateway.jar';

(3)编写每个jar包的Dockerfile文件

Dockerfile-eureka:

FROM java:8-jre

ADD ./jar/pig-eureka.jar /app/

CMD ["java", "-Xmx200m", "-jar", "/app/pig-eureka.jar"]

EXPOSE 1025

Dockerfile-config(其他的类似):

FROM java:8-jre

ADD ./netcat.tar.gz /opt/                  #netcat的压缩包必须放在同级目录下   

ENV NETCAT_HOME /opt/netcat

ENV PATH $PATH:$NETCAT_HOME/bin       #在容器里安装netcat命令

ADD ./jar/pig-config.jar /app/

CMD ["java", "-Xmx200m", "-jar", "/app/pig-config.jar"]

EXPOSE 4001

netcat放在同级目录下

(4)启动服务

$ docker-compose up

其他程序都在等待eureka启动这样就实现了顺序启动的功能




注意问题:

1. Shell脚本权限问题(不能执行shell脚本):

docker: Error response from daemon: OCI runtime create failed: container_linux.go:348: starting container process caused "exec: \"docker-entrypoint.sh\": executable file not found in $PATH": unknown.

解决方法(添加权限)

chmod +x docker-entrypoint.sh

2. Shell脚本报错"start.sh  /bin/bash^M: 坏的解释器:没有那个文件或目录”,因为 .sh文件是从windows拷贝过来的,所以多了\r

解决办法

 sed -i 's/\r$//' start.sh   

3. 出现网关不能no host to root

先关闭防火墙看是否能解决

4. 关闭防火墙后会出现NO chain需要重启docker


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,589评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,615评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,933评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,976评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,999评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,775评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,474评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,359评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,854评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,007评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,146评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,826评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,484评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,029评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,153评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,420评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,107评论 2 356