Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pdacity/docker_gc
Garbage collector for Docker Swarm / Автоматическая сборка мусора для Docker и Docker Swarm
https://github.com/pdacity/docker_gc
docker-cloud docker-gc docker-service docker-swarm
Last synced: 3 months ago
JSON representation
Garbage collector for Docker Swarm / Автоматическая сборка мусора для Docker и Docker Swarm
- Host: GitHub
- URL: https://github.com/pdacity/docker_gc
- Owner: pdacity
- License: mit
- Created: 2019-12-09T18:43:22.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-02-09T17:50:47.000Z (12 months ago)
- Last Synced: 2024-08-01T05:20:41.230Z (6 months ago)
- Topics: docker-cloud, docker-gc, docker-service, docker-swarm
- Language: Shell
- Homepage:
- Size: 25.4 KB
- Stars: 95
- Watchers: 2
- Forks: 20
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-docker - docker_gc - Image for automatic removing unused Docker Swarm objects. Also works just as Docker Service by [@pdacity](https://github.com/pdacity) (Development with Docker / Garbage Collection)
- awesome - pdacity/docker_gc - Garbage collector for Docker Swarm / Автоматическая сборка мусора для Docker и Docker Swarm (others)
README
# Garbage collector for Docker Swarm
![Awesome Docker](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)
![Docker Cloud Build Status](https://img.shields.io/docker/cloud/build/pdacity/docker_gc)
![Docker stuff](https://img.shields.io/badge/%F0%9F%90%B3-useful%20stuff-lightgray)
![PizzaWare](https://img.shields.io/badge/%F0%9F%8D%95-PizzaWare-orange)
![Tea powered](https://img.shields.io/badge/%F0%9F%8D%B5-tea%20powered-yellowgreen)## About
Image for automatic removing unused Docker Swarm objects. Also works just as Docker Service.
By default these types of objects are deleted:
- container
- volume
- network## Configuration
Set config parameters in the yml file:
* AGE - the max time for resource to be unused (format: timestamp or Go duration strings (10m, 1h30m))
* SLEEP - the time frame between checking for unused objects (format: timestamp or Go duration strings (10m, 1h30m))
* STICKY_LABEL - do not remove image with this label### Building image with `STICKY_LABEL`
If you need to protect an image from automatic deletion use LABEL directive, for example: `persistent_image=true`. To do it just create Dockerfile for you image .
```yaml
FROM
LABEL persistent_image=true
```Before run the stack build the image from Dockerfile mentioned above:
docker-compose.yaml
```yaml
...
container_name:
build:
context: .
...```
* `` - the image which is protected from automatic deletion
* `` - service name in the stack
* `` - container name (optionally)Also you should set `STICKY_LABEL: persisten_image=true` in the docker_gc run variables
## Run
* docker-stack.yml - to deploy the service in Docker Swarm
* docker-compose.yml - to run just a Docker Service## Docker Hub
Prebuild docker image on hub.docker.com - https://hub.docker.com/r/pdacity/docker_gc
---
# Сборщик мусора для Docker Swarm и Docker
![Docker Cloud Build Status](https://img.shields.io/docker/cloud/build/pdacity/docker_gc)
![Docker stuff](https://img.shields.io/badge/%F0%9F%90%B3-useful%20stuff-lightgray)
![PizzaWare](https://img.shields.io/badge/%F0%9F%8D%95-PizzaWare-orange)
![Tea powered](https://img.shields.io/badge/%F0%9F%8D%B5-tea%20powered-yellowgreen)## О проекте
Образ для автоматической очистки неиспользуемых обьектов в Docker Swarm (работает и просто как Docker Service )
По умолчанию удаляются следующие типы обьектов:
- container
- volume
- network## Настройка
Для работы необходимо задать параметры yml файле:
* AGE - срок в формате timestamp или Go duration strings (10m, 1h30m) после которого неиспользуемые ресурсы будут удалены
* SLEEP - периодичность проверки в формате timestamp или Go duration strings (10m, 1h30m)
* STICKY_LABEL - не удалять образа с этой меткой### Сборка образа с `STICKY_LABEL`
В случае если необходимо защитить какой либо из образов от автоматического удаления необходимо добавить к образу `label`, например `persistent_image=true` Для этого создайте Dockerfile для образа ``
```yaml
FROM
LABEL persistent_image=true
```При запуске стека необходимо собрать образ из приведенного выше Dockerfile
docker-compose.yaml
```yaml
...
container_name:
build:
context: .
...```
где `` - название образа который должен быть защищен от автоматического удаления, `` - название сервиса в стеке, `` имя контейнера (опционально)И задайте `STICKY_LABEL: persistent_image=true` в переменных запуска docker_gc
## Запуск
* docker-stack.yml - для деплоя сервиса в Docker swarm
* docker-compose.yml - для запуска Docker Service## Docker Hub
Готовый собранный образ на hub.docker.com - https://hub.docker.com/r/pdacity/docker_gc
## Star History
[![Star History Chart](https://api.star-history.com/svg?repos=pdacity/docker_gc&type=Timeline)](https://star-history.com/#pdacity/docker_gc&Timeline)
---
References:
English version of the documentation - https://habr.com/en/users/AlexanderTyutin/