Limiter ressources daemon docker via daemon.json
Résolu
Bonjour,
Dans l'optique de limiter les ressources du daemon docker, j'ai testé plusieurs façons de faire.
- Premier façon de faire qui fonctionne pour moi
1- Créer un fichier "fichier.slice" avec les données suivantes
2- Declarer le nouveau fichier .slice dans le bloc [Service] du fichier docker.service
3- Reload daemon et restart docker
- Seconde façon de faire qui ne fonctionne pas pour moi
1- Créer un fichier "fichier.slice" avec les données suivantes
2- Creation du fichier "daemon.json" avec les données suivantes
3- Reload daemon et restart docker
La question
Avez vous une idée pourquoi en passant par le daemon.json cela ne fonctionne pas?
Les logs n'indique rien et la commande
Merci
Dans l'optique de limiter les ressources du daemon docker, j'ai testé plusieurs façons de faire.
- Premier façon de faire qui fonctionne pour moi
1- Créer un fichier "fichier.slice" avec les données suivantes
[Unit]
Description=Throttle CPU usage to 70% and memory usage to 8GB for docker-spawned processes
Before=slices.target
[Slice]
CPUQuota=50%
MemoryAccounting=true
MemoryMax=20G
2- Declarer le nouveau fichier .slice dans le bloc [Service] du fichier docker.service
Slice=monfichier.slice
3- Reload daemon et restart docker
- Seconde façon de faire qui ne fonctionne pas pour moi
1- Créer un fichier "fichier.slice" avec les données suivantes
[Unit]
Description=Throttle CPU usage to 70% and memory usage to 8GB for docker-spawned processes
Before=slices.target
[Slice]
CPUQuota=50%
MemoryAccounting=true
MemoryMax=20G
2- Creation du fichier "daemon.json" avec les données suivantes
{
"exec-opts": ["native.cgroupdriver=systemd"],
"cgroup-parent": "/monfichier.slice"
}
3- Reload daemon et restart docker
La question
Avez vous une idée pourquoi en passant par le daemon.json cela ne fonctionne pas?
Les logs n'indique rien et la commande
pcsystemctl status dockerindique failed mais rien d'autre.
Merci
A voir également:
- Limiter ressources daemon docker via daemon.json
- Daemon tools - Télécharger - Émulation & Virtualisation
- Net limiter - Télécharger - Outils Internet
- Via michelin carte - Télécharger - Transports & Cartes
- Partager des photos via un lien - Guide
- ViaMichelin - Télécharger - Transports & Cartes
10 réponses
Bonjour,
Je ne connais pas bien
Bonne chance
Je ne connais pas bien
docker, mais voici ce que je vérifierais en premier lieu :
- Es-tu sûr que ton fichier
daemon.json
est lu ? D'après la documentation,docker
va lire par défaut/etc/docker/daemon.json
ou utiliser le chemin passé en paramètre via l'option--config-file string
. - Arrives-tu as exploiter le fichier
monfichier.slice
via l'option--cgroup-parent
? (voir dans la documentation la section "Default cgroup parent"). En particulier, est-ce quemonfichier.slice
est placé un dossier inspecté par docker (est-ce que la valeur associée àcgroup-parent
est cohérente) ?
Bonne chance
Bonjour,
Unable to configure the Docker daemon with file
Effectivement, il n'y a pas de manière d'écrire des commentaires dans un fichier
Bon par contre ce qui est curieux c'est que malgré cela mon
Tu veux dire dans
En tout cas, difficile à dire pour moi vue que la capture d'écran est tronquée. De manière générale, évite les captures d'écran sur un forum, un bon vieux copier coller sera plus pratique pour tout le monde et plus écologique.
Retour à ton problème : il faut regarder dans tes logs voir si quelque chose explique pourquoi ta directive n'est pas prise en compte. Si les logs de docker sont bien faits, ils devraient t'indiquer les fichiers lus, les instructions appliquées avec succès, et les éventuelles erreurs. C'est à partir de ces informations qu'on comprendra mieux ce qui cloche, soit par nous-même, soit en cherchant les messages d'erreur sur Internet...
Par contre si je renseigne la ligne
Ce qui est sûr c'est qu'il faut redémarrer (ou recharger) les services adéquats pour qu'un changement de configuration soit pris en compte. Est-ce bien le cas ?
Pardonne ma méconnaissance de
Bonne chance
Unable to configure the Docker daemon with file
/etc/docker/daemon.json: invalid character '#' looking for beginning of value
Effectivement, il n'y a pas de manière d'écrire des commentaires dans un fichier
json. Mais, comme tu le soulignes, cette erreur confirme que le fichier
/etc/docker/daemon.jsonest bien lu.
Bon par contre ce qui est curieux c'est que malgré cela mon
cgroup-parent "cgroup-parent": "limit-docker-resource.slice"qui est présent dans mon fichier
daemon.logsemble ne pas être pis en compte comme on peut le voir avec un
systemctl status docker!
Tu veux dire dans
/etc/docker/daemon.json?
En tout cas, difficile à dire pour moi vue que la capture d'écran est tronquée. De manière générale, évite les captures d'écran sur un forum, un bon vieux copier coller sera plus pratique pour tout le monde et plus écologique.
Retour à ton problème : il faut regarder dans tes logs voir si quelque chose explique pourquoi ta directive n'est pas prise en compte. Si les logs de docker sont bien faits, ils devraient t'indiquer les fichiers lus, les instructions appliquées avec succès, et les éventuelles erreurs. C'est à partir de ces informations qu'on comprendra mieux ce qui cloche, soit par nous-même, soit en cherchant les messages d'erreur sur Internet...
Par contre si je renseigne la ligne
Slice=limit-docker-resource.slicedans mon
/etc/systemd/system/docker.serviceet que je redémarre les services c'est pris en compte!
Ce qui est sûr c'est qu'il faut redémarrer (ou recharger) les services adéquats pour qu'un changement de configuration soit pris en compte. Est-ce bien le cas ?
Pardonne ma méconnaissance de
dockermais es-tu sûr qu'un
cgrouppeut être un slice, ou s'agit-il de deux notions différentes ?
Bonne chance
En effet, je viens de tomber sur cette discussion qui semble correspondre exactement à ton problème. As-tu essayer de suivre en particulier cette réponse ?
Bonne chance
Bonne chance
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Enfin c'est résolu!
Merci.
J'ai supprimé
D'ailleurs cette commande
ATTENTION
Pour info si d'autres personnes ont besoin, le paramètre
L'accès au savoir est la première liberté que chaque homme devrait avoir.
Merci.
J'ai supprimé
Slice=limit-docker-resource.slicedans mon
/etc/systemd/system/docker.serviceet fait un
pcsystemctl start limit-docker-resource.sliceet c'etait good
D'ailleurs cette commande
systemd-cgtopl'indique
Control Group Tasks %CPU Memory Input/s Output/s
/limit-docker-resource.slice 902 61.3 9.2G - -
/limit-docker-resource.slice/689eb9a 36 5.7 361.6M - -
/limit-docker-resource.slice/a51e874 36 5.6 361.7M - -
ATTENTION
Pour info si d'autres personnes ont besoin, le paramètre
MemoryLimit=indiqué dans cette réponse ( https://unix.stackexchange.com/questions/537645/how-to-limit-docker-total-resources/550954#550954) est obsolète et remplacé par
MemoryMax=. Consulter le MAN de "systemd.resource-control"
L'accès au savoir est la première liberté que chaque homme devrait avoir.
Merci.
Alors oui mon fichier
Par contre effectivement, tu m'as mis la puce a l'oreille concernant le path du fichier
Alors oui mon fichier
daemon.jsonest bien lu car si je l'active justement il plante de daemon docker. Et il est bien dans
/etc/docker.
Par contre effectivement, tu m'as mis la puce a l'oreille concernant le path du fichier
monfichier.slicepour que docker l'exploite! Je vais vérifier cela.
Bin après vérification je comprends toujours pas!
Voici le contenu de mon fichier daemon.json qui est dans /etc/docker
et voici le contenu du fichier
Le cgroup
/sys/fs/cgroup/memory/limit.slice/limit-docker.slice/limit-docker-resource.slice/
Voici le contenu de mon fichier daemon.json qui est dans /etc/docker
{
"exec-opts": ["native.cgroupdriver=systemd"],
"cgroup-parent": "limit-docker-resource.slice"
}
et voici le contenu du fichier
limit-docker-resource.slicequi se trouve dans /etc/systemd/system
[Unit]
Description=Throttle CPU usage to 70% and memory usage to 8GB for docker-spawned processes
Before=slices.target
[Slice]
CPUQuota=50%
MemoryAccounting=true
MemoryMax=20G
Le cgroup
/sys/fs/cgroup/memory/limit.slice/limit-docker.slice/limit-docker-resource.slice/
Merci car en fait je ne regardais pas le bon log et du coup en testant ce matin j'ai trouvé ou était l"erreur et pourquoi le daemon docker plantait. Cela venait du commentaire présent dans
Bon par contre ce qui est curieux c'est que malgré cela mon cgroup-parent

Par contre si je renseigne la ligne

daemon.log. Cela confirme également que docker lit bien le fichier.
unable to configure the Docker daemon with file /etc/docker/daemon.json: invalid character '#' looking for beginning of value
Bon par contre ce qui est curieux c'est que malgré cela mon cgroup-parent
"cgroup-parent": "limit-docker-resource.slice"qui est présent dans mon fichier
daemon.logsemble ne pas être pis en compte comme on peut le voir avec un
systemctl status docker!

Par contre si je renseigne la ligne
Slice=limit-docker-resource.slicedans mon /etc/systemd/system/docker.service et que je redémarre les services c'est pris en compte!
