howto:弹性beanstalk +部署docker +优雅关机
嗨,大家好,
在EB上托管Docker容器,并在其上运行基于Nodejs的代码。 当重新部署我们的码头集装箱时,我们希望旧码头能够正常关闭。
我已经找到了关于我们的代码如何接收由'docker stop'命令产生的sigterm信号的帮助和指南。
然而,进一步调查EB机器运行/opt/elasticbeanstalk/hooks/appdeploy/enact/01flip.sh
: /opt/elasticbeanstalk/hooks/appdeploy/enact/01flip.sh
显示,当从目前的“翻转”到新的阶段性容器时,旧的容器会被'docker kill'
有没有办法将这种行为改变为码头停靠?
或者一般来说推荐的方法来处理旧容器的正常关闭?
谢谢!
自我回答,因为我找到了适合我们的解决方案:
tl; dr:使用.ebextensions脚本在01flip之前运行你的脚本,你的脚本将确保docker内部发起者的正常关闭发生
首先 ,您的应用程序(或任何您在docker中运行的应用程序)必须能够捕获信号,例如SIGINT,并优雅地关闭它。
这与Docker完全无关,你可以在任何地方(例如本地)测试它的运行情况。有很多关于为网上不同类型的应用程序完成这种行为的信息(无论是ruby,node.js等等)。 。)
其次 ,基于EB / Docker的项目可以包含一个.ebextensions文件夹,该文件夹包含在部署时执行的所有脚本。 我们将2个自定义脚本放入它中,看起来像这样的gracefulshutdown_01.config和gracefulshutdown_02.config文件:
# gracefulshutdown_01.config
commands:
backup-original-flip-hook:
command: cp -f /opt/elasticbeanstalk/hooks/appdeploy/enact/01flip.sh /opt/elasticbeanstalk/hooks/appdeploy/01flip.sh.bak
test: '[ ! -f /opt/elasticbeanstalk/hooks/appdeploy/01flip.sh.bak ]'
cleanup-custom-hooks:
command: rm -f 05gracefulshutdown.sh
cwd: /opt/elasticbeanstalk/hooks/appdeploy/enact
ignoreErrors: true
和:
# gracefulshutdown_02.config
commands:
reorder-original-flip-hook:
command: mv /opt/elasticbeanstalk/hooks/appdeploy/enact/01flip.sh /opt/elasticbeanstalk/hooks/appdeploy/enact/10flip.sh
test: '[ -f /opt/elasticbeanstalk/hooks/appdeploy/enact/01flip.sh ]'
files:
"/opt/elasticbeanstalk/hooks/appdeploy/enact/05gracefulshutdown.sh":
mode: "000755"
owner: root
group: root
content: |
#!/bin/sh
# find currently running docker
EB_CONFIG_DOCKER_CURRENT_APP_FILE=$(/opt/elasticbeanstalk/bin/get-config container -k app_deploy_file)
EB_CONFIG_DOCKER_CURRENT_APP=""
if [ -f $EB_CONFIG_DOCKER_CURRENT_APP_FILE ]; then
EB_CONFIG_DOCKER_CURRENT_APP=`cat $EB_CONFIG_DOCKER_CURRENT_APP_FILE | cut -c 1-12`
echo "Graceful shutdown on app container: $EB_CONFIG_DOCKER_CURRENT_APP"
else
echo "NO CURRENT APP TO GRACEFUL SHUTDOWN FOUND"
exit 0
fi
# give graceful kill command to all running .js files (not stats!!)
docker exec $EB_CONFIG_DOCKER_CURRENT_APP sh -c "ps x -o pid,command | grep -E 'workers' | grep -v -E 'forever|grep' " | awk '{print $1}' | xargs docker exec $EB_CONFIG_DOCKER_CURRENT_APP kill -s SIGINT
echo "sent kill signals"
# wait (max 5 mins) until processes are done and terminate themselves
TRIES=100
until [ $TRIES -eq 0 ]; do
PIDS=`docker exec $EB_CONFIG_DOCKER_CURRENT_APP sh -c "ps x -o pid,command | grep -E 'workers' | grep -v -E 'forever|grep' " | awk '{print $1}' | cat`
echo TRIES $TRIES PIDS $PIDS
if [ -z "$PIDS" ]; then
echo "finished graceful shutdown of docker $EB_CONFIG_DOCKER_CURRENT_APP"
exit 0
else
let TRIES-=1
sleep 3
fi
done
echo "failed to graceful shutdown, please investigate manually"
exit 1
gracefulshutdown_01.config是一个小的util,用于备份原始的flip01并删除(如果存在)我们的自定义脚本。
gracefulshutdown_02.config是魔术发生的地方。 它创建了一个05年可靠的关闭制定脚本,并确保翻转后将其重命名为10flip。
05gracefulshutdown,自定义脚本,这基本上是这样做的:
这假设你只有1台docker在机器上运行,并且你可以手动跳上去检查它发生故障时的错误(对于我们从未发生过的事情)。
我想它也可以在很多方面得到改善,所以玩得开心。
上一篇: howto: elastic beanstalk + deploy docker + graceful shutdown
下一篇: How to detect external displays in android prior API 17