AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 789556
Accepted
F1Linux
F1Linux
Asked: 2025-01-14 18:48:48 +0800 CST2025-01-14 18:48:48 +0800 CST 2025-01-14 18:48:48 +0800 CST

Como configurar limites do Cgroup V2 em contêineres docker-compose

  • 772

Quero configurar a limitação de recursos do cgroups V2 em um contêiner Docker-Compose. Como faço isso?

systemd
  • 1 1 respostas
  • 183 Views

1 respostas

  • Voted
  1. Best Answer
    F1Linux
    2025-01-14T18:48:48+08:002025-01-14T18:48:48+08:00

    INTRODUÇÃO:

    Eu como minha própria comida de cachorro e tenho usado essa solução por alguns anos em contêineres docker-compose voltados para o público. Então, ela é suficientemente testada em batalha e a evidência do teste no final prova que sim .

    Esta solução de 2 etapas leva apenas 2 minutos para configurar o Cgroup V2 em seus contêineres Docker-Compose

    REQUISITOS:

    Apenas (2) requisitos:

    • Docker Host OS : Um host SystemD que suporta Cgroup V2. Eu uso Ubuntu 24.04.1 LTS com esta solução
    • versão docker-compose : Um arquivo docker-compose formatado usando v3.9. Mas qualquer versão que suporte a croup_parentdiretiva deve funcionar

    Validado em versões anteriores às acima, mas deve ser portátil sem modificações em qualquer distribuição SystemD Linux que suporte Cgroup v2

    Observe que a configuração é específica do contêiner!!! : Embora eu execute a solução em contêineres Alpine Linux e Ubuntu AARCH64, ela poderia ser em outros contêineres Docker do Arch - NÃO há configuração ou dependências no nível do contêiner.

    PASSO 1: Configuração do HOST:

    Crie um arquivo chamado "docker.slice" no seguinte caminho:

    /etc/systemd/system/docker.slice

    Abaixo está uma configuração de uso geral; ajuste para valores sensatos para seu caso de uso específico:

    [Unit]
    Description=Slice that limits docker resources 
    Before=slices.target
    
    [Slice]
    MemoryAccounting=true
    CPUAccounting=true
    TasksMax=30%
    AllowedCPUs=1-3
    # NOTE: If slice restricted to 3 of 4 cores, max avail. CPUQuota= 300%, NOT 400%
    CPUQuota=300%
    # CPUWeight value range: 1-10000
    CPUWeight=8000
    MemoryLow=1G
    MemoryHigh=2G
    MemoryMax=2G
    # IOWeight value range: 1-10000
    IOWeight=5000
    

    Leia suas novas alterações:

        systemctl daemon-reload
    

    PASSO 2 Configuração do DOCKER-COMPOSE:

    No arquivo docker-compose, na cgroup_parentdiretiva, especifique o nome do arquivo systemd criado na Etapa 1:docker.slice

        cgroup_parent: docker.slice
    

    Formatação Jason : Estou inserindo (4) espaços antes de adicionar a cgroup_parentdiretiva no 5º espaço no meu próprio arquivo docker-compose.

    Reinicie os contêineres docker-compose.

    Agora quando você executa:

    systemctl status docker.slice
    

    Você verá seu contêiner rodando sob o controle de recursos do Cgroups. Sua configuração do Cgroups V2 para seu contêiner docker-compose está concluída. É isso!

    (ETAPA OPCIONAL) CONFIG- CONTAINER:

    Reconstruir contêiner com stress-ngpara validar a limitação de recursos está funcionando. Exclua stress-ngdo seu processo de construção de contêiner após o teste ser concluído.

    Mas se você estiver satisfeito que a solução funciona conforme proposto depois de analisar as evidências do meu teste abaixo, você pode simplesmente pular esta etapa.

    TESTE:

    Teste de estresse:

    Usaremos stress-ng dentro do contêiner para provar que nossos limites de Cgroup estão sendo aplicados. Há um zilhão stress-ngde comandos que podemos usar para testar várias coisas, mas vou oferecer apenas um único teste, pois não é para ser um HowTo 'stress-ng'.

    Entre no contêiner:

    docker exec -it <Container ID from "docker ps"> sh
    

    Ou se bashestiver disponível dentro do seu contêiner (precisa adicioná-lo expressamente no Alpine Linux):

    docker exec -it <Container ID from "docker ps"> bash
    

    Uma vez dentro do contêiner que estamos testando para limitação de recursos do Cgroup, execute o teste de estresse:

    stress-ng --cpu 0 --iomix 4 --vm 16 --vm-bytes 4G --timeout 180s --metrics
    

    Note que definimos nossa limitação de recursos para memória para um valor máximo de 2G em docker.slice. Assim, vamos limitar a memória usando um valor de 4G no stress-ngcomando acima. Se tudo estiver configurado corretamente, nunca devemos ver nada acima de 2G.

    Limitação de recursos de monitoramento:

    Em uma nova janela/guia do terminal, execute os seguintes comandos de monitoramento para validar se as limitações estão sendo aplicadas corretamente.

    OBSERVAÇÃO : os comandos abaixo devem ser executados no HOST - NÃO dentro do contêiner!

    systemctl status docker.slice
    systemd-cgtop
    

    Algumas capturas de tela são oferecidas abaixo para evidenciar que nossa configuração Cgroups V2 está funcionando corretamente. Observe, no entanto, que a saída após todos os stress-ngcomandos é truncada para clareza ilustrativa.

    systemctl status docker.slice:

    systemctl status docker.slice Saída

    systemd-cgtop:

    Saída systemd-cgtop

    dmesg |grep -i oomSaída:

    Observação oom-kill:constraint=CONSTRAINT_MEMCG. Cgroups está dando um golpe stress-ngquando tenta passar nosso limite de memória: "dmesg |grep -i oom"

    CONCLUSÃO:

    Demorei um pouco para fazer o Cgroups funcionar no docker-compose devido à falta de um HowTo abrangente. Como eu estava portando o OpenLDAP para o AARCH64, achei que valia a pena reservar um momento para documentar o processo que sigo para evitar que outros tenham que arrancar os cabelos da cabeça para fazê-lo funcionar. ;-)

    De qualquer forma, HTH e outras pessoas da empresa que estavam procurando em vão por alguma ajuda de configuração-

    -Terrence Houlahan

    • 0

relate perguntas

  • Níveis diferenciadores no journalctl

  • Altere o editor padrão para vim para _ sudo systemctl edit [unit-file] _

  • systemd: como posso executar um script no início de um serviço, sem editar a definição do serviço

  • Use o suporte de watchdog do systemd para reiniciar o aplicativo

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve