4

我正在使用ansible playbook在Jenkins中使用docker部署我的应用程序,最近我想限制应用程序容器的日志大小,“docker run”有“–log-opt max-size=xxxm”选项,但是我该怎么做在 ansible playbook 中添加相同的功能?

我尝试将 ansible playbook 设置如下,但测试表明它不起作用。

  - name: start container
    docker_container:
      name: "{{docker_container}}"
      image: "{{docker_image}}"
      log_options:
        max-size: 256m
        max-file: 2
      volumes:
        - "/etc/timezone:/etc/timezone"
        - "/etc/localtime:/etc/localtime"
      published_ports:
        - "{{published_ports}}"
      recreate: yes

我想限制大小的容器日志文件的位置如下文件:

/var/lib/docker/containers/2fdcae9fb35f4954639a3ff254873f0ae8518f2ede011807/2fdcae9fb35f4954639a3ff254873f0ae8518f2ede0118072304077918deb20f-json.log

先谢谢你的回复:)

4

2 回答 2

0

为什么不登录到系统日志?

您的 ansible 剧本将如下所示:

  - name: start container
docker_container:
    name: "{{docker_container}}"
    image: "{{docker_image}}"
    volumes:
      - "/etc/timezone:/etc/timezone"
      - "/etc/localtime:/etc/localtime"
    published_ports:
      - "{{published_ports}}"
    recreate: yes
    log_driver: syslog
    log_options:
      tag: "{{docker_container}}"
      syslog-facility: local4

您的系统日志配置可能如下所示(/etc/rsyslog.d/22-docker.conf):

local4.*         /var/log/docker.log

就我而言(Ubuntu 16.04),syslog 会自动维护日志文件的大小。

于 2018-03-03T16:06:22.710 回答
0

我不知道你是否看到这个警告

[WARNING]: log_options is ignored when log_driver is not specified

您可以尝试设置 log_driver:json-file 如下

- name: Run docker container
  docker_container:
    name: "{{ docker_name }}"
    image: "test/test:{{ image_tag }}"
    log_driver: json-file
    log_options:
      max-size: 100m
    recreate: yes
于 2021-07-19T02:28:56.470 回答