Docker-compose編排微服務順序啟動解決方案


實際項目中遇到的問題,eureka server如果在其他service后啟動,會導致部分service一直無法注冊成功,

參考網上的經驗,原文:https://www.jianshu.com/p/d2f39703bcb5,做下總結:

主要三種方式,其中第一種是無效的,但是很多博客沒更新。

1. 用到了docker-compose 中的 restart配置:restart: always

2. 拆分原來的docker-compose.yml,分成兩部分部署, 將要先啟動的服務放在一個docker-compose中,后啟動的服務放在第二個docker-compose中,

啟動兩次,需要在networks標簽中指定兩者使用同一個網絡。

$ docker-compose -f docker-compose-commond.yml up

 3. 同步等待,使用shell腳本阻止當前服務啟動,直到所需依賴的服務全部啟動之后再啟動當前服務。docker-compose文件中在服務下加入entrypoint,注:這種寫法會覆蓋dockerfile中的entrypoint和cmd,一定要注意!

volumes: - "./entrypoint.sh:/entrypoint.sh" 
environment: SLEEP_SECOND: 4 
tty: true
entrypoint: /entrypoint.sh -d simonEureka:8100 -c 'java -jar config-server.jar';

 entrypoint.sh如下,網上抄來的,可以根據需求自行定制:

#!/bin/bash

: ${SLEEP_SECOND:=2} #默認兩秒后重試
wait_for() { 
	echo Waiting for $1 to listen on $2...
	while ! ncat -z $1 $2; #nc命令用telnet協議測試端口
	do echo waiting...; 
		sleep $SLEEP_SECOND;
	done }
	
declare DEPENDS 
declare CMD 
while getopts "d:c:" arg 
do 
	case $arg in 
		d) 
			DEPENDS=$OPTARG 
			;; 
		c) 
			CMD=$OPTARG 
			;; 
		?) 
		echo "unkonw argument" exit 1 
			;; 
	esac 
done 

for var in ${DEPENDS//,/ } ### ${DEPENDS//,/ }把DEPENDS中的,替換為空格
do 
	host=${var%:*} 
	port=${var#*:} 
	wait_for $host $port 
done 
eval $CMD ##eval命令相當於把$CMD中的命令執行一次
#避免執行完命令之后退出容器
tail -f /dev/null

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM