本文为大家介绍容器自启动以及docker 守护过程挂掉或者docker降级的状况下,如何保障容器服务的失常运行。次要蕴含三个局部
一、守护过程开机自启
在咱们装置docker的时候,介绍过启动docker守护过程的命令如下,须要人工手动执行。
systemctl start docker
如果咱们心愿在linux服务器启动的时候,就主动启动Docker守护过程,无需人工干预,就应用上面的命令即可
systemctl enable docker.service;
上面的两个命令大家依据本人的须要,在适合的场景下应用即可。
# 删除docker守护过程开机自启动配置systemctl disable docker.service;# 重新配置docker守护过程开机自启动systemctl reenable docker.service;
二、容器自启动
docker守护过程主动启动之后,如果咱们心愿某些容器可能随之也自启动提供并服务,在容器创立时应用如下命令即可:
# 留神`--restart unless-stopped`是可能实现自启动的要害参数docker run -d --restart unless-stopped nginx
如果咱们曾经存在一个运行时容器,想让它减少容器自启动的能力,应用如下命令即可
docker update --restart unless-stopped nginx
重启策略阐明
unless-stopped是笔者比拟罕用的重启策略,除此之外docker还提供了其余的重启策略,--restart
的值能够是以下任何一种:
重启策略标记 | 形容 |
---|---|
no | 不要主动重启容器。(默认) |
on-failure[:max-retries] | 如果容器因程序运行谬误退出(非正常退出),则重新启动容器。可选项配置:max-retries 示意尝试重新启动容器的最大次数,超过这个次数还启动失败就不重启了。 |
always | 如果容器处于进行状态,则始终重新启动容器。例外情况:如果该容器是运维人员手动进行的,只有在Docker守护过程产生重启或者容器自身手动重启之后,才会持续always重启策略。 |
unless-stopped | 在进行Docker守护程序之前曾经处于进行状态的容器,不会执行重启。其余的和always一样。 |
为什么我经常应用unless-stopped重启策略?
- 一个服务器上有很多容器,其中一些是我手动进行的(被动行为)。这些容器即便重启服务器或重启docker守护过程之后,我也不心愿它们主动运行。所以我不必always。
- 在重启服务器或重启docker守护过程之前,处于良好运行状态的容器,在重启服务器或重启docker守护过程之后,通常也不会呈现因程序运行谬误导致的无奈重启的问题,所以我不必on-failure。
三、守护过程进行期间保障容器服务失常
本文以上探讨的都是服务器重启、docker守护过程重启之后如何保障容器的运行状态,并且尽量不须要人工参加。本大节次要阐明的内容是:如果咱们要降级docker的版本,咱们要进行docker的守护过程,然而咱们不想影响容器向用户提供服务。即:docker守护过程停了,想要保障docker容器过程依然运行,这该怎么做?
默认状况下,当 Docker 守护过程终止时,它会敞开基于它运行的所有容器。然而能够通过配置形式,在守护程序过程不可用时放弃容器运行。此性能称为live-restore。live-restore有助于缩小因为守护过程解体、打算中断或降级导致的容器进行服务的工夫。
{ "live-restore": true}
配置形式就是在/etc/docker/daemon.json
配置文件中退出下面的一行,这样守护过程进行之后,容器不会进行服务。
欢送关注我的布告号:字母哥杂谈,回复003赠送本文所在专栏《docker修炼之道》的PDF版本,30余篇精品docker文章。字母哥博客:zimug.com