首页
学习
活动
专区
圈层
工具
发布

Docker容器设置自动重启

有时Docker服务出现异常,或者服务器出现异常,需要重启Docker服务或者服务器; 如果希望有一部分基础的或者常用的容器,在服务或者服务器重启的时候,可以实现自动启动,仅需使用命令进行简单配置即可实现...Docker 容器设置为自动重启,分为两种情况:新建容器时设置,和对已经存在的容器设置。...1、使用镜像创建新的容器运行 创建容器的时候设置容器为自动重启,命令行中加参数 –restart=always,命令如下: docker run -d --restart=always --name 设置容器名...=password --name postgres postgres:latest 2、已有的容器更新为自动重启 docker update --restart=always 容器ID(或者容器名) 1...在容器非正常退出时(退出状态非0),才会重启容器 on-failure:3 在容器非正常退出时重启容器,最多重启3次 always 在容器退出时总是重启容器 unless-stopped 在容器退出时总是重启容器

3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    docker容器的重启策略

    docker 的容器运行后并不会是永远就运行了,和宿主机的资源分配等等都有关系,各种意外会导致容器意外退出,手动重启容器肯定是非常愚蠢的一件事情。...unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器,也就是说,如果 docker 的守护进程启动后,然后因为一些其它原因导致容器退出,将不会重启容器...二,容器的退出状态码 docker run 的退出状态码如下: 0,表示正常退出 非 0,表示异常退出(退出状态码采用 chroot 标准) 125,Docker 守护进程本身的错误 126,容器启动后...,要执行的默认命令无法调用 127,容器启动后,要执行的默认命令不存在 其他命令状态码,容器启动后正常执行命令,退出命令时该命令的返回状态码作为容器的退出状态码** 三,容器重启策略的应用场景 容器有两种运行方式...一种是前台运行,此时运行的容器将打印容器运行日志到屏幕上。

    3.4K30

    机器重启后 docker 容器启动报错 error creating overlay mount to

    机器重启后 docker 容器启动报错 error creating overlay mount to 作者:张首富 时间:2020-07-29 w y:y18163201 今天早上来到公司发现,发现机器上的容器全部停止了...,已查看机器在夜里被关机重启了,然后启动容器之后报错如下: Error response from daemon: error creating overlay mount to /var/lib/docker.../overlay2/67fc837e52765051b9f1559ac561a6f196aa0e88521909dc3352c7409d2e0236/merged: invalid argument Error...: failed to start containers: jieba 这个问题的是由于selinux造成的 CentOS的selinux是关闭的,而docker上的selinux却是开启的,因此docker...另外docker 18.09已经废弃使用overlay了,overlay2存储才是今后所支持的.

    5.8K21

    机器重启后 docker 容器启动报错 error creating overlay mount t

    机器重启后 docker 容器启动报错 error creating overlay mount to 作者:张首富 时间:2020-07-29 w y:y18163201 今天早上来到公司发现,发现机器上的容器全部停止了...,已查看机器在夜里被关机重启了,然后启动容器之后报错如下: Error response from daemon: error creating overlay mount to /var/lib/docker.../overlay2/67fc837e52765051b9f1559ac561a6f196aa0e88521909dc3352c7409d2e0236/merged: invalid argument Error...: failed to start containers: jieba 这个问题的是由于selinux造成的 CentOS的selinux是关闭的,而docker上的selinux却是开启的,因此docker...另外docker 18.09已经废弃使用overlay了,overlay2存储才是今后所支持的.

    1.9K62

    如何设置Docker容器重启策略?

    开始之前 宿主机可能会因某些原因(如宕机)重新启动,默认情况下docker容器是停止状态的,这可能会对某些应用场景带来不便,所以docker提供了--restart参数,在创建容器时设置此参数,docker...always 无论容器退出状态如何,Docker守护进程无限期地尝试重新启动容器。...小结 最后来总结下文章中的知识点 没有显示指定restart参数创建的容器,docker将会使用默认值No,也就是不会重新启动容器。...对于某些关键应用场景,建议首选 unless-stopped 或者 on-failure选项,好处是不会无限制地重启容器。...always选项建议作为次选,因为当容器内部应用错误而停止(非零退出状态),docker仍然不断地尝试重新启动容器。

    3.3K40

    Docker容器的日志处理

    Docker有很多的日志插件,默认使用 json-file,只有使用json-file时,sudo docker logs -f 才可以显示,输入以下命令查看docker日志插件: $ sudo docker...我们都知道docker logs -f会将所有对应的服务日志输出到终端,无论服务的部署在哪个节点上,那么我现在提出一个问题,是否每个节点对应的容器文件,都会保存该服务的完整日志备份,还是只保存该节点服务对应容器产生的日志...因为这个问题涉及到每个节点如果都用filebeat监听宿主机的容器日志文件,那么每个节点的容器日志都是一个完整的备份,日志就会重复,所以答案是每个节点只保留该节点上容器的日志,docker logs -...f 命令只不过在overlay网络模型上走了一层协议,把在其它节点上的相同的容器日志汇聚起来。...中,不然json-file日志驱动不会收集到容器里面输出的日志,sudo docker logs -f就在终端显示不了容器日志了,在Dockerfile中需加入以下命令: RUN ln -sf /dev

    1.7K30

    Docker容器的日志处理

    Docker有很多的日志插件,默认使用 json-file,只有使用json-file时,sudo docker logs -f 才可以显示,输入以下命令查看docker日志插件: $ sudo docker...我们都知道docker logs -f会将所有对应的服务日志输出到终端,无论服务的部署在哪个节点上,那么我现在提出一个问题,是否每个节点对应的容器文件,都会保存该服务的完整日志备份,还是只保存该节点服务对应容器产生的日志...因为这个问题涉及到每个节点如果都用filebeat监听宿主机的容器日志文件,那么每个节点的容器日志都是一个完整的备份,日志就会重复,所以答案是每个节点只保留该节点上容器的日志,docker logs -...f 命令只不过在overlay网络模型上走了一层协议,把在其它节点上的相同的容器日志汇聚起来。...中,不然json-file日志驱动不会收集到容器里面输出的日志,sudo docker logs -f就在终端显示不了容器日志了,在Dockerfile中需加入以下命令: RUN ln -sf /dev

    3K40

    Docker 容器日志管理Fluentd

    随着Docker容器广泛应用,,大规模运行的容器集群来说,日志不能集中管理是一件很痛苦的事情。不能合理的收集,管理检索应用日志,在应用发生了故障的时候将无法很好的追溯问题发生的原因。...容器id>.log,所有收集到的日志文件将存储至此。...2、启动一个测试容器查看日志是否存储到fluentd # docker run -d --log-driver fluentd --log-opt fluentd-address=localhost:24224...异步设置,避免fluentd挂掉之后导致Docker容器也挂了 配置好之后访问nginx页面,每次刷新会出现如下日志 2018-05-03T07:21:55+00:00    nginx-test   ...再启动一个测试容器,可以查看到日志同样存储到Fluentd 参考文档: 1、https://www.fluentd.org/guides/recipes/docker-logging 2、安装文档:

    1.8K10

    Docker容器日志管理实践

    }}' 查看单个容器的设置的日志驱动 docker inspect -f '{{.HostConfig.LogConfig.Type}}' 容器id 全局修改日志驱动(针对所有的容器的日志驱动),...{ "log-driver": "local", "log-opts": { "max-size": "10m" } } 重启 docker 即可生效。...,日志文件会继续写入到 container.log,但是会将 container.log 日志中老的日志删除,追加新的,也就是 当写满 100MB 日志后 ,再产生一条新日志,会删除 container.log...# 查看日志,日志名称就是 容器名称-json.log tail -f /var/lib/docker/containers/199608b2e2c52136d2a17e539e9ef7fbacf97f1293678aded421dadbdb006a5e...CMD ["catalina.sh", "run"] 我们运行了一个 Tomcat 容器 ,然后进行访问后,并登陆到容器内部,我们可以看到产生了文本日志: root@25ba00fdab97:/usr/

    4K21

    Docker容器日志管理最佳实践

    日志分为两类: Docker 引擎日志(也就是 dockerd 运行时的日志), 容器的日志,容器内的服务产生的日志。...'{{.LoggingDriver}}' 查看单个容器的设置的日志驱动 docker inspect -f '{{.HostConfig.LogConfig.Type}}' 容器id Docker...,日志文件会继续写入到 container.log,但是会将 container.log 日志中老的日志删除,追加新的,也就是 当写满 100MB 日志后 ,再产生一条新日志,会删除 container.log...# 查看日志,日志名称就是 容器名称-json.log tail -f /var/lib/docker/containers/199608b2e2c52136d2a17e539e9ef7fbacf97f1293678aded421dadbdb006a5e...CMD ["catalina.sh", "run"] 我们运行了一个 Tomcat 容器 ,然后进行访问后,并登陆到容器内部,我们可以看到产生了文本日志: root@25ba00fdab97:/usr/

    4.1K10

    Docker容器日志接入到GrayLog

    Docker容器日志接入到GrayLog 本文参考如下链接完成 https://docs.docker.com/config/containers/logging/gelf/ (图片点击放大查看)...1、/etc/docker/daemon.json中加入如下配置并重启服务 { "log-driver": "gelf", "log-opts": { "gelf-address...[root@localhost ~]# (图片点击放大查看) 2、新建一个测试容器 docker run -d -it --name nginx_test -p 80:80 nginx:latest...docker ps (图片点击放大查看) 3、Graylog上面配置GELF Input,Stream,查询模板 (图片点击放大查看) (图片点击放大查看) (图片点击放大查看) 4、接入的容器日志在...GrayLog上的查询效果如下 (图片点击放大查看) (图片点击放大查看) 5、当然也可以使用如下方法单独接入某个容器的日志 容器启动中加入如下参数 docker run \ --log-driver

    1.3K10

    使用Fluentd收集Docker容器日志

    本文介绍使用Fluentd收集standalone容器日志的方法。...Docker提供了很多logging driver,默认情况下使用的json-file,它会把容器打到stdout/stderr的日志收集起来存到json文件中,docker logs所看到的日志就是来自于这些...当有多个docker host的时候你会希望能够把日志汇集起来,集中存放到一处,本文讲的是如何通过fluentd logging driver配合fluentd来达成这一目标。...目标: 将standalone容器打到stdout/stderror的日志收集起来 收集的日志根据容器名分开存储 日志文件根据每天滚动 第一步:配置Fluentd实例 首先是配置文件fluent.conf...logging driver 在启动容器的时候执行使用fluentd作为logging driver: docker run -d \ ...

    2.6K10
    领券