一、概述
docker-compose可以方便组合多个 docker 容器服务, 但是, 当容器服务之间存在依赖关系时, docker-compose 并不能保证服务的启动顺序。docker-compose 中的 depends_on 配置是容器的启动顺序, 并不是容器中服务的启动顺序。本章将详细叙述如何解决 docker-compose 顺序启动微服务的问题。
微服务清单
服务名 | 端口 | 服务说明 | 依赖服务 | 启动优先级 |
eureka-service | 8761 | 服务注册与发现 | --- | 1 |
auth-service | 8888 | 认证服务 | eureka-service | 2 |
user-service | 8763 | 用户服务 | eureka-service | 2 |
gateway-service | 8081 | 网关服务 | eureka-service | 2 |
说明:eureka需要第一个启动,其他微服务必须等待eureka启动之后,才能启动。否则无法注册服务!
二、解决方案
针对这个问题,docker-compose官方给的建议是,通过wait-for-it.sh脚本来控制。
简单来说,这个脚本就是探测某个依赖的服务的tcp端口是否开放,否则一直等待,直到端口探测成功,才会启动后面的命令。
关于wait-for-it.sh的使用,请参考链接:
https://blog.csdn.net/wuzhong8809/article/details/82500722
环境说明
本文采用一台centos 7.6,通过docker-compose启动java spring cloud
ip地址:192.168.128.130
但是我测试了一下,使用wait-for-it.sh探测eureka的8761端口。发现虽然端口探测成功了,但是并不代表eureka完全启动好了。因此此时无法访问eureka的页面!
那么如何判断eureka完全启动好了呢?很简单,只需要访问eureka页面,http状态码为200,就表示启动好了。
curl -I -m 10 -o /dev/null -s -w %{http_code} http://eureka-server:8761
那么问题来了,还是得需要自己写检查脚本才行。
check_eureka.sh
#!/bin/bash while : do # 访问eureka注册中心,获取http状态码 CODE=`curl -I -m 10 -o /dev/null -s -w %{http_code} http://kitedge-eureka-server:8761` # 判断状态码为200 if [[ $CODE -eq 200 ]]; then # 输出绿色文字,并跳出循环 echo -e "