利用 Watchtower 自动监听并更新正在运行的 Docker 容器

本文首发于只抄博客,欢迎点击原文链接了解更多内容。

前言

大部分 VPS 和 NAS 用户或多或少都有用 Docker 来部署一些 Self-hosting 的服务,其中大部分项目都是开源项目,更新频率非常高,特别是一些版本 0.x 的项目,及时的将 Docker 容器更新到最新版本不仅可以体验到新特性,还能减少 BUG。

但是一旦部署的容器多起来,就不知道到底哪一个项目更新了,哪一个项目没有更新,即便是有类似 Portainer、Dockge 之类的可视化工具,更新 Docker 容器还是一件麻烦事。

而今天介绍的 Watchtower 可以帮助我们解决这个烦恼,启动 Watchtower 后,它将监控正在运行的 Docker 容器以及这些容器最初启动时所用的镜像是否发生变化。如果检测到镜像发生更改,Watchtower 会拉取新的镜像,然后正常关闭现有容器,再使用最初部署时的相同选项重新启动它。

简单用法

Watchtower 本身也是一个 Docker 容器,你可以直接通过 docker run 来启动它,所有的容器都会自动更新

谨慎运行以下代码,所有的容器都会更新!更多的配置请继续往后面看!

sh 复制代码
docker run -d \
    --name watchtower \
    -v /var/run/docker.sock:/var/run/docker.sock \
    containrrr/watchtower

配置项

由于默认情况下的 Watchtower 会更新的所有的容器,我们可以通过配置项来进行设置,Watchtower 提供的配置项非常的多,可以参考官方文档,下面只介绍最常用的几个配置项。

更新指定容器

如果不希望更新所有的容器,只需要将要自动更新的容器名作为参数写在启动命令中,例如下面的命令只会更新 nginx 和 redis

sh 复制代码
docker run -d \
    --name watchtower \
    -v /var/run/docker.sock:/var/run/docker.sock \
    containrrr/watchtower \
    nginx redis

忽略指定容器

如果你不希望某个容器不更新,可以通过 --disable-containers 参数(简写为 -x)将其忽略

清理旧镜像

如果你希望在容器更新完成后,自动清理旧的镜像,可以添加上 --cleanup 参数(简写为 -c

运行频率

默认情况下,Watchtower 会一直运行,以 86400s 的频率轮询检测 Docker 容器是否有更新,你可以通过 --interval 参数(简写为 -i)修改其运行频率,单位为秒,也可以通过 --schedule 参数(简写为 -s)来让他定时运行,参数为 6 字段的 Cron 表达式,两个参数只能选择其中一个

手动运行

默认情况下,Watchtower 是轮询检测 Docker 容器更新的,你也可以通过 --run-once 参数(简写为 -R)来让它只运行一次,每次运行完毕后 Watchtower 都会自动退出并删除自身

完整用法

上面的这些配置项看的一头雾水?没关系,下面给出完整的 Docker Compose 包含常用的一些配置项,每天的凌晨 4 点会自动更新所有的 Docker 容器,并且将旧镜像移除。如果需要更新指定容器或者忽略指定容器,只需要在 command 后面加上对应的容器名即可

sh 复制代码
services:
  watchtower:
    image: containrrr/watchtower
    container_name: watchtower
    network_mode: host
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
      - /etc/localtime:/etc/localtime:ro
    command: --cleanup --schedule "0 0 4 * * *"
相关推荐
孤的心了不冷2 分钟前
【Docker】CentOS 8.2 安装Docker教程
linux·运维·docker·容器·eureka·centos
头疼的程序员1 小时前
docker学习与使用(概念、镜像、容器、数据卷、dockerfile等)
学习·docker·容器
IT小郭.1 小时前
使用 Docker Desktop 安装 Neo4j 知识图谱
windows·python·sql·docker·知识图谱·database·neo4j
淡水猫.1 小时前
hbit资产收集工具Docker(笔记版)
运维·docker·容器
.生产的驴2 小时前
Vue3 加快页面加载速度 使用CDN外部库的加载 提升页面打开速度 服务器分发
运维·服务器·前端·vue.js·分布式·前端框架·vue
程序员JerrySUN2 小时前
Linux 内核核心知识热点题分析:10 个连环打通的难点
linux·运维·服务器
水淹萌龙7 小时前
k8s 中使用 Service 访问时NetworkPolicy不生效问题排查
云原生·容器·kubernetes
honey ball8 小时前
R & S的EMI接收机面板
linux·运维·网络
木下-俱欢颜9 小时前
搭建基于chrony+OpenSSL(NTS协议)多层级可信时间同步服务
运维·网络安全·udp·ssl
alden_ygq9 小时前
K8S cgroups详解
容器·贪心算法·kubernetes