项目作者: stephenmoloney

项目描述 :
A standalone docker container designed to clear the log files for a docker container at specified intervals.
高级语言: Shell
项目地址: git://github.com/stephenmoloney/docker-log-cleaner.git
创建时间: 2017-02-05T14:18:20Z
项目社区:https://github.com/stephenmoloney/docker-log-cleaner

开源协议:MIT License

下载


log-cleaner

Features

  • A standalone docker container.
  • Designed to clear the log files for a docker container at specified intervals.
  • Can be used for clearing logs in multiple containers.
  • Only functional with the driver: "json-file".

Startup commands

  1. sudo docker-compose up -d

force recreate and show logs

  1. sudo docker-compose up -d --build --force-recreate && sudo docker-compose logs -f

Environment variables

  • CLEAN_FREQUENCY - an integer and represents seconds so 60 = 1 minute, 3600 = 1 hour
  • CONTAINERS_T0_CLEAN - the container_name of the containers to have their logs cleaned.
  • INCLUDE_SELF - whether the current container (log-cleaner by default) should also have it’s logs cleaned, defaults to TRUE
  • SELF_NAME - name of the current container (defaults to log_cleaner)

Examples

The following docker-compose.yml example will clear the logs of containers with names mongo nginx
every 3600 seconds (hourly)

  1. version: '2'
  2. services:
  3. log-cleaner:
  4. image: smoloney/docker-log-cleaner:latest
  5. build:
  6. context: .
  7. dockerfile: Dockerfile
  8. container_name: log-cleaner
  9. restart: unless-stopped
  10. volumes:
  11. - /var/run/docker.sock:/var/run/docker.sock
  12. - /var/lib/docker/containers/:/var/lib/docker/containers/
  13. environment:
  14. - CLEAN_FREQUENCY=3600
  15. - CONTAINERS_T0_CLEAN=mongo nginx
  16. - INCLUDE_SELF=FALSE
  17. logging:
  18. driver: "json-file"
  19. options:
  20. max-size: "1m"
  21. max-file: "1"

The following docker-compose.yml example will clear the logs of containers with names mongo nginx log-cleaner
every 3600 seconds (hourly)

  1. version: '2'
  2. services:
  3. log-cleaner:
  4. image: smoloney/docker-log-cleaner:latest
  5. build:
  6. context: .
  7. dockerfile: Dockerfile
  8. container_name: log-cleaner
  9. restart: unless-stopped
  10. volumes:
  11. - /var/run/docker.sock:/var/run/docker.sock
  12. - /var/lib/docker/containers/:/var/lib/docker/containers/
  13. environment:
  14. - CLEAN_FREQUENCY=3600
  15. - CONTAINERS_T0_CLEAN=mongo nginx
  16. - INCLUDE_SELF=TRUE
  17. logging:
  18. driver: "json-file"
  19. options:
  20. max-size: "1m"
  21. max-file: "1"

The following docker-compose.yml example will clear the logs of containers with names mongo nginx my-logger-cleaner
every 3600 seconds (hourly)

  1. version: '2'
  2. services:
  3. log-cleaner:
  4. image: smoloney/docker-log-cleaner:latest
  5. build:
  6. context: .
  7. dockerfile: Dockerfile
  8. container_name: my-logger-cleaner
  9. restart: unless-stopped
  10. volumes:
  11. - /var/run/docker.sock:/var/run/docker.sock
  12. - /var/lib/docker/containers/:/var/lib/docker/containers/
  13. environment:
  14. - CLEAN_FREQUENCY=3600
  15. - CONTAINERS_T0_CLEAN=mongo nginx
  16. - INCLUDE_SELF=TRUE
  17. - SELF_NAME=my-logger-cleaner
  18. logging:
  19. driver: "json-file"
  20. options:
  21. max-size: "1m"
  22. max-file: "1"

Notes

  • This project is not designed as a replacement for the docker-compose logging directives
    but rather as an adjunct to the logging directive.
  • If this feature is implemented in docker then this project will become defunct and hopefully this will be the case. There
    was an issue about this in docker/compose in github.

Acknowledgement

Licence

MIT Licence