关于 docker-compose stop 和 docker-compose start 的误解
目录
问题
自己在原有镜像 1.0 的基础上,修改了一个问题,重新编译打包新镜像 2.0,然后更新了 docker-compose.yml 中的版本号,停止并启动容器,发现原来的问题还没有解决。但是,自己明明已经改了。很奇怪!
解决
步骤一、确认新镜像中可执行程序是否正确
使用新镜像,启动一个容器服务,进入容器,发现可执行程序已经是最新了。
使用可执行程序特定的版本检查命令可以知道是新包,命令如下:
./bag -v
步骤二、 查看当前容器依赖的镜像版本是否正确
既然新镜像本身是正确的,那么就需要看看当前运行的容器依赖的是不是最新的镜像包即可,执行如下命令查看:
docker inspect bag
果然有问题,通过执行结果(下图)可以知道,当前运行的容器依赖的还是之前的镜像版本。
那就奇怪了,明明 docker-compose.yml 文件中已经修改了版本号。
步骤三、验证更新命令是否正确
对别的容器使用相同的命令,验证是否可以正确更新镜像版本,验证命令如下:
docker-compose stop test
docker-compose start test
结果很打脸,确实也没有更新。但是,自己明明记得之前这样操作是有效的。于是,自己查看官方的介绍文档,其中也明确说明:docker-compose stop 只会停止当前容器,不会删除容器。因此,再执行 docker-compose start 命令之后,只会把原来的容器重新启动。所以,我们看到的现象就是镜像没有更新。尴尬😅!
这里补充一点,其实,除了 docker-compose stop 和 docker-compose start 命令之外还有一个神奇的命令 docker-compose restart,而且三者之间存在如下关系:
docker-compose restart = docker-compose stop + docker-compose start
嘿嘿,是不是很有意思。
步骤四、使用正确的更新命令
如果修改了 docker-compose.yml 中的配置信息,想让这些改动生效,可以使用如下命令:
docker-compose up -d
看到这个命令是不是很熟悉,是的,首次启动容器的时候也是使用这个命令。
如果这样不好理解的话,也可以使用如下组合命令来让 docker-compose.yml 中修改的配置生效:
docker-compose down
docker-compose up -d
其中,docker-compose down 命令会首先停止容器,然后再删除容器。因此,又有一个和上面类似的公示:
docker-compose down = docker-compose stop + docker-compose rm
注意:上文说的配置文件特指 docker-compose.yml 文件。如果 docker-compose.yml 文件又依赖了其他配置文件,比如 config.yml。如果修改了 config.yml 中的配置项,那么,docker-compose up -d 命令就不好使了,此时,我们就需要重启容器才可以,docker-compose restart 命令就开始“登台表演”了。
最后,我们看一组演示命令:
参考链接
docker-compose up | Docker Documentation
作者简介:😄大家好,我是 Data-Mining(liuzhen007),是一位典型的音视频技术爱好者,前后就职于传统广电巨头和音视频互联网公司,具有丰富的音视频直播和点播相关经验,对 WebRTC、FFmpeg 和 Electron 有非常深入的了解,😄公众号:玩转音视频。同时也是 CSDN 博客专家、华为云享专家(共创编辑)、InfoQ 签约作者,欢迎关注我分享更多干货!😄
版权声明: 本文为 InfoQ 作者【liuzhen007】的原创文章。
原文链接:【http://xie.infoq.cn/article/b22ed8926782ca029dd5d6b77】。文章转载请联系作者。
评论