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,自定义脚本,这基本上是这样做的:

  • 找到当前正在运行的码头
  • 找到所有需要发送SIGINT的进程(对于我们而言,其名称中包含'worker'的进程
  • 发送sigint到上述过程
  • 循环:
  • 检查来自之前的进程是否被杀死
  • 继续循环尝试一次
  • 如果尝试结束,退出状态“1”,不要继续10flip,需要手动干预。
  • 这假设你只有1台docker在机器上运行,并且你可以手动跳上去检查它发生故障时的错误(对于我们从未发生过的事情)。
    我想它也可以在很多方面得到改善,所以玩得开心。

    链接地址: http://www.djcxy.com/p/28849.html

    上一篇: howto: elastic beanstalk + deploy docker + graceful shutdown

    下一篇: How to detect external displays in android prior API 17