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 / computer / Perguntas / 1599762
Accepted
NZD
NZD
Asked: 2020-11-05 14:22:09 +0800 CST2020-11-05 14:22:09 +0800 CST 2020-11-05 14:22:09 +0800 CST

O desligamento não pode desligar o contêiner docker (systemd)

  • 772

Estou executando vários contêineres docker no meu servidor Ubuntu. Eles são controlados pelo systemd.

Se eu executar systemctl stop [email protected]o container desliga normalmente. A saída de journalctl é a seguinte (saída em tempo reverso, mais recente no topo):

Nov 05 10:58:11 ubox0 systemd[1]: Stopped Docker container startup for mw/salcom/app.
Nov 05 10:58:11 ubox0 docker[3622]: mw-salcom-app
Nov 05 10:58:09 ubox0 docker[3470]: [Thu Nov 05 10:58:09.921033 2020] [mpm_prefork:notice] [pid 1] AH00169: caught SIGTERM, shutting down
Nov 05 10:58:09 ubox0 systemd[1]: Stopping Docker container startup for mw/salcom/app...

Se eu, no entanto, executar shutdown -h now, recebo:

Nov 05 10:51:04 ubox0 systemd[1]: Stopped Docker container startup for mw/salcom/app.
Nov 05 10:51:04 ubox0 systemd[1]: [email protected]: Failed with result 'timeout'.
Nov 05 10:51:04 ubox0 systemd[1]: [email protected]: Main process exited, code=killed, status=9/KILL
Nov 05 10:51:04 ubox0 systemd[1]: [email protected]: Killing process 2077 (docker) with signal SIGKILL.
Nov 05 10:51:04 ubox0 systemd[1]: [email protected]: State 'stop-sigterm' timed out. Killing.
Nov 05 10:50:04 ubox0 systemd[1]: [email protected]: Stopping timed out. Terminating.
Nov 05 10:49:04 ubox0 systemd[1]: Stopping Docker container startup for mw/salcom/app...

O contêiner não é interrompido e o processo eventualmente expira após 2 minutos e o contêiner é abortado.

Qual é a razão para isto?

Eu gostaria que meus contêineres fossem desligados normalmente para que os serviços executados neles fossem interrompidos sem perda de dados.

Meu arquivo de serviço é:

[Unit]
Description=Docker container startup for %I
Requires=docker.service
After=docker.service

[Service]
TimeoutStartSec=40
Restart=always
# wait a while before restarting in case we are doing a restore;
# this includes a 'docker stop' command after we restore the data
RestartSec=60
ExecStartPre=-/usr/bin/docker stop %i
ExecStart=/usr/bin/docker start -a %i
ExecStop=/usr/bin/docker stop %i
TimeoutStopSec=60

[Install]
WantedBy=multi-user.target

Atualização Depois de pesquisar mais, encontrei essa postagem Como lidar adequadamente com um contêiner do Docker como um serviço do systemd? descreve o mesmo problema, mas não há resposta lá.

docker shutdown
  • 1 1 respostas
  • 954 Views

1 respostas

  • Voted
  1. Best Answer
    NZD
    2020-12-24T12:41:59+08:002020-12-24T12:41:59+08:00

    Parece que docker e systemd nem sempre se dão muito bem, veja:

    • https://github.com/moby/moby/issues/6791
    • https://github.com/ibuildthecloud/systemd-docker

    Eu tenho exatamente a mesma configuração em uma máquina diferente (meu servidor de backup) e aqui tudo funciona bem. Eu posso executar o comando de desligamento e todos os contêineres do docker são desligados normalmente.

    Portanto, o problema pode ser um problema de dependência. Talvez o systemd tenha encerrado algum serviço necessário aos contêineres do docker para que eles possam ser encerrados corretamente.

    A versão do docker no sistema que 'falha' é 18.09.2, no sistema que 'funciona' é 18.06.1-ce.

    o notas de versão do estado da versão do docker 18.09:

    In Docker versions prior to 18.09, containerd was managed
    by the Docker engine daemon. In Docker Engine 18.09, 
    containerd is managed by systemd.
    

    Quando adicionei as seguintes linhas aos meus arquivos de unidade:

    [Unit]
    ...
    Requires=containerd.service
    After=containerd.service
    

    e recarreguei os arquivos da unidade ( systemctl daemon-reload), as coisas começaram a funcionar novamente. Meus contêineres não foram encerrados após o tempo limite de 1 minuto que defini, mas foram encerrados após alguns segundos.

    Eu tentei atualizar o docker para a versão20.10.1 primeiro, sem sucesso.

    Tive a ideia dessa 'solução' quando me deparei com: https://github.com/sous-chefs/docker/issues/1062

    • 0

relate perguntas

  • Shutdown.exe - Altere o caminho no registro

  • Problema ao buscar http://deb.debian.org/debian/dists/jessie-updates/InRelease com docker

  • Nginx dá 404 para alguns arquivos

  • execute o contêiner do docker como root

  • Comunique-se com o daemon do Docker no Windows

Sidebar

Stats

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

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

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