强制异常容器重启,让你的Docker锦上添花

这篇具有很好参考价值的文章主要介绍了强制异常容器重启,让你的Docker锦上添花。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

docker compose 配置 unhealthy的时候自动重启,docker,eureka,容器,运维,云原生

在没有HEALTHCHECK指令之前,Docker只能通过process是否退出来判断container的状态,不过有时候服务已经无法正常运作了,但process没有退出,这样会导致该服务仍然可以接收用户请求,但是无法正常响应。我们需要对这种容器进行识别并自动重启。

今天我们接着上次的docker健康检查机制那篇文章,讲述一下如何给不健康的容器进行重启。新近关注的用户可以点击后面的链接查看如何添加健康检查机制,巧用Docker健康检查,让你的容器如虎添翼。另外有读者反馈有几个参数不是很理解,我们会在这篇文章里再补充讲解一下。

Docker在1.12版本之后提供了HEALTHCHECK指令,可以设定一行command用来判断服务的状态是否正常,这样可以更准确地判断服务状态。

HEALTHCHECK Container启动后的初始状态为starting,在指令检查成功后,状态会更改为healthy,如果连续失败超过指定次数则会改为unhealthy。看下HealthCheck的工作机制。

docker compose 配置 unhealthy的时候自动重启,docker,eureka,容器,运维,云原生

HEALTHCHECK参数选项:

--interval: Health check时间间隔,预设为30秒

--timeout:当Health check超过此设定的时间,则会视为失败,预设为30秒

--retries:当Health check连续失败次数超过此设定时,则会将状态更改为,预设为3次unhealthy

--start-period:启动时间,预设为0秒

HEALTHCHECK可以通过Dockerfile或是docker-compose.yml设定:

Dockerfile 示例

在Dockerfile中,HEALTHCHECK指令格式为

HEALTHCHECK [options] CMD <command>

<command>可以是shell指令或是exec格式(和其他Dockerfile指令相同,可以参考ENTRYPOINT)。而一个Dockerfile中只能有一个HEALTHCHECK指令,如果同时有多个HEALTHCHECK指令,则只有最后一个有效。

<command>的返回值代表container的状态:

0:成功,container is healthy

1:失败,如果失败超过指定次数,则container为unhealthy

2: reserved,不要使用这个值

假设我们的container服务是web服务,我们可以使用来检查服务是否正常运行,例如:每30秒检查一次是否可在5秒内响应请求:curl http://localhost:3000

# ...


HEALTHCHECK --interval=30s --timeout=5s --retries=5 --start_period=30s \
  CMD curl -fs http://localhost:3000/ || exit 1


# ...

Docker-compose 示例

docker-compose.yml的healthcheck,示例如下:

version: "3.7"
services:
  api:
    restart: always
    image: api
    container_name: api
    ports:
      - 3000:3000
    build:
      context: ./api
    healthcheck:
      test: curl -fs http://localhost:3000/ || exit 1
      interval: 30s
      timeout: 5s
      retries: 5
      start_period: 30s
    networks:
      - net
networks:
  net:
    name: net
    driver: bridge

其中test必须是string或list.如果是list,第一个item必须是NONE,或CMD-SHELL。如果是string,则等同于CMD-SHELL。

确认健康状态

在设定好health check指令之后,接着启动container,检查container状态时可以看到初始状态是:health: starting

$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                            PORTS                       NAMES
6c7b9ca321d2        api:1.0.0           "uwsgi --ini /home/d…"   5 seconds ago       Up 2 seconds (health: starting)   0.0.0.0:3000->3000/tcp      api

过30秒之后再执行一次docker ps,可以看到container的状态变成:healthy

$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                            PORTS                       NAMES
6c7b9ca321d2        api:1.0.0           "uwsgi --ini /home/d…"   35 seconds ago      Up 32 seconds (healthy)           0.0.0.0:3000->3000/tcp      api

而如果连续失败超过指定次数,状态会变成unhealthy。

docker compose 配置 unhealthy的时候自动重启,docker,eureka,容器,运维,云原生

关键步骤:重新启动不正常的容器

以上的步骤只有检查container的健康状态,但没有针对unhealthy container做任何处理,这部分我们可以搭配docker-autoheal来重启unhealthy container。先看下AutoHeal的工作机制。

docker compose 配置 unhealthy的时候自动重启,docker,eureka,容器,运维,云原生

autoheal可以直接使用docker执行,或是写在docker-compose中:

使用 docker 指令:

$ docker run -d \
    --name autoheal \
    --restart=always \
    -e AUTOHEAL_CONTAINER_LABEL=all \
    -v /var/run/docker.sock:/var/run/docker.sock \
    willfarrell/autoheal

使用docker-compose指令:

version: "3.7"
services:
  autoheal:
    restart: always
    image: willfarrell/autoheal
    container_name: autoheal
    environment:
      - AUTOHEAL_CONTAINER_LABEL=all
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock

然后执行 docker-compose up -d autoheal 就可以启动。

启动之后可以通过docker ps观察unhealthy的容器是否重启了。也可以查看autoheal的日志查看是否有启动记录。

最后再给大家介绍一种模拟unhealthy的方法,正常情况下都是healthy的,可以通过修改命令来模拟unhealthy。比如模拟mysql的服务,我们可以使用如下命令。

test: ["CMD", "nc -vz localhost 3307 || exit 1"]

正常监听3306端口,我们用3307连接检查,就会一直处于unhealthy状态,这个时候我们可以通过autoheal的日志观察到对mysql容器的重启。

有了这个机制,以后docker假死的情况就可以自动重启了。这个检查和自动重启机制对于数据库或者tomcat服务都非常有用。如果使用过程中有什么问题也欢迎发消息给我们。

docker compose 配置 unhealthy的时候自动重启,docker,eureka,容器,运维,云原生文章来源地址https://www.toymoban.com/news/detail-840242.html

到了这里,关于强制异常容器重启,让你的Docker锦上添花的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • docker重启容器

    docker重启容器

    2024年02月16日
    浏览(47)
  • docker容器重启故障

    强杀docker进程后,重启docker。docker中的容器无法启动并报错 docker restart XXXXXXX Error response from daemon: Cannot restart container XXXXXXX: container ‘XXXXXXXXXXXXXXXX’: already exists 原因:旧容器未安全退出 解决方式: docker-containerd-ctr --address /run/docker/containerd/docker-containerd.sock --namespace c rm 容器

    2024年04月13日
    浏览(113)
  • docker容器重启策略

    当使用docker run命令运行一个容器的时候,使用--restart选项可以配置该容器的重启策略。 no 不要自动重启容器(默认) on-failure[:max-retries] 如果容器发生错误导致退出(非0退出状态),则重启该容器。可以使用 :max-retries 选项限制尝试重启的次数。 always 如果容器退出了,总是

    2023年04月18日
    浏览(49)
  • docker—启动、停止、重启容器实例

    docker—启动、停止、重启容器实例

    先查看已经暂停的容器实例信息 docker ps -a 通过 docker start xxx 启动容器 通过 docker ps 查看当前启动的容器 1、docker stop 此方式常常被翻译为优雅的停止容器 docker stop 容器ID或容器名 参数 -t:关闭容器的限时,如果超时未能关闭则用kill强制关闭,默认值10s,这个时间用于容器的

    2024年02月09日
    浏览(45)
  • Docker 容器设置为 自动重启

    有时Docker服务出现异常,或者服务器出现异常,需要重启Docker服务或者服务器; 如果希望有一部分基础的或者常用的容器,在服务或者服务器重启的时候,可以实现自动启动,仅需使用命令进行简单配置即可实现。 Docker 容器设置为自动重启,分为两种情况:新建容器时设置

    2024年02月07日
    浏览(49)
  • Docker 容器设置为自动重启

    Docker 容器设置为自动重启

     Docker自动重启原因 Docker自动重启通常是由以下几个原因导致的: 程序崩溃 系统内存不足 系统进程使用过多CPU和RAM导致的阻塞 docker容器被杀死或重新启动,导致应用程序中断 网络中断 当这些问题出现时,Docker会自动重启运行中的服务来尝试解决问题。 docker update --restart

    2024年02月03日
    浏览(51)
  • Docker 查询、停止、删除和重启容器

    docker 列出所有容器ID docker 查看所有运行容器 docker 查看正在运行容器 docker 停止指定的 container (容器) 温馨提示:删除 container (容器) 的镜像文件,必须先停止 container (容器) 运行 。 知识拓展:停止docker 所有容器(包含正在运行) container (容器) docker 删除指定的

    2024年02月03日
    浏览(58)
  • 无法停止删除容器,Mac重启Docker

    不能停止、杀死、删除容器,使用以下命令得到错误消息: 无法停止、杀死、删除容器,因为没有接收退出事件“receive an exit event”。 没有找到强制停止容器的方法,只能重启容器:

    2024年02月07日
    浏览(45)
  • docker篇---重启策略 + run 容器常用参数

    container runctime 负责的是容器的生命周期管理 OCI :(open container initiative)开源容器协议, 包含两个规范:运行规范(runctime spec)-对容器状态、创建、删除、查看定义 镜像规范(image-spec)-如何创建一个OCI 运行时的系统包 CRI (container run interface) 容器运行接口 隔开了各个

    2024年02月12日
    浏览(44)
  • 在Docker守护进程停机期间保持容器运行(即重启Docker时,正在运行的容器不会停止)

      在默认情况下,当 Docker 守护进程终止时,它将关闭正在运行的容器。不过,我们可以配置该守护进程,以便在该守护进程不可用时容器仍在运行。这种功能称为实时恢复。实时还原选项有助于减少由于守护进程崩溃、计划中断或升级而导致的容器停机时间。 Docker官方相关

    2024年02月03日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包