Eu tenho o arquivo de composição do docker com o PostgreSQL e meu aplicativo, assim:
version: '3'
services:
postgresql:
image: postgres:9.6.6
ports:
- 9932:5432
expose:
- "5432"
environment:
- POSTGRES_PASSWORD=pass
restart: always
volumes:
- /data:/var/lib/postgresql/data
myapp:
image: myapp
links:
- postgresql
depends_on:
- "postgresql"
restart: always
ports:
- "5000:5000"
O problema é que a restart: always
política parece não funcionar quando eu mato o container (simulando a falha do aplicativo usando docker kill
) e o docker-compose não reinicia meu container, mesmo que o código de saída seja 137 . Eu observo o mesmo comportamento quando uso restart: on-failure
a política. As versões 2
e 3
do docker-compose se comportam da mesma forma. Meu sistema é o Ubuntu Server 16.04 x64.
Minhas perguntas são:
- Por que o docker-compose não reinicia o contêiner travado (eliminado)?
- Como verificar se a política de reinicialização funciona?
Quando você usa o docker kill, esse é o comportamento esperado, pois o Docker não reinicia o contêiner: "Se você interromper manualmente um contêiner, sua política de reinicialização será ignorada até que o daemon do Docker seja reiniciado ou o contêiner seja reiniciado manualmente. Esta é outra tentativa de evitar um loop de reinicialização" (referência)
Se você usar docker stop ou docker kill, você interromperá manualmente o contêiner. Você pode fazer alguns testes sobre as políticas de reinicialização: reiniciar o daemon do docker, reinicializar seu servidor, usar um CMD dentro de um contêiner e executar uma saída...
Por exemplo, se eu matar meu contêiner implantado com uma política de reinicialização, vejo que ele saiu com o código 137, mas não foi reiniciado de acordo com docker ps -a, ele permanece encerrado:
Mas se eu reiniciar o daemon...
O contêiner que foi definido com a política de reinicialização é iniciado novamente, o que é o que a documentação diz, portanto, o docker kill não é a maneira como você deve testar a política de reinicialização, pois supõe-se que você interrompeu deliberadamente o contêiner e o Docker deseja ter uma maneira de impedir a reinicialização loops, se você matá-lo, você realmente quer matá-lo.
Achei valiosos os links a seguir que mostram o mesmo comportamento em diferentes versões (portanto, não é um bug, mas o comportamento esperado):