Réponse tardive, mais pourrait aider quelqu'un
docker run/exec -iconnectera le STDIN de la commande à l'intérieur du conteneur au STDIN de docker run/execlui - même.
Alors
docker run -i alpine catvous donne une ligne vide en attente de saisie. Tapez "bonjour" vous obtenez un écho "bonjour". Le conteneur ne sortira pas tant que vous n'aurez pas envoyé CTRL+ Dcar le processus principal catattend l'entrée du flux infini qui est l'entrée terminale du docker run.
- D'un autre côté,
echo "hello" | docker run -i alpine cataffichera "bonjour" et quittera immédiatement car il catremarque que le flux d'entrée s'est terminé et se termine lui-même.
Si vous essayez docker psaprès avoir quitté l'un des éléments ci-dessus, vous ne trouverez aucun conteneur en cours d'exécution. Dans les deux cas, catlui - même s'est terminé, donc docker a terminé le conteneur.
Maintenant pour "-t", cela indique au processus principal dans docker que son entrée est un terminal.
Alors
docker run -t alpine catvous donnera une ligne vide, mais si vous essayez de taper "bonjour", vous n'obtiendrez aucun écho. En effet, alors que catest connecté à une entrée de borne, cette entrée n'est pas connectée à votre entrée. Le «bonjour» que vous avez tapé n'a pas atteint l'entrée de cat. catattend une entrée qui n'arrive jamais.
echo "hello" | docker run -t alpine catvous donnera également une ligne vide et ne quittera pas le conteneur CTRL- Dmais vous n'aurez pas d'écho "bonjour" car vous n'avez pas réussi-i
Si vous envoyez CTRL+ C, vous récupérez votre shell, mais si vous essayez docker psmaintenant, vous voyez le catconteneur toujours en cours d'exécution. En effet, catil attend toujours un flux d'entrée qui n'a jamais été fermé. Je n'ai trouvé aucune utilisation utile pour le -tseul sans être combiné avec -i.
Maintenant, pour -itensemble. Cela indique à cat que son entrée est une borne et en même temps connectez cette borne à l'entrée docker rundont est une borne. docker run/execs'assurera que sa propre entrée est en fait un tty avant de la passer à cat. C'est pourquoi vous obtiendrez un input device is not a TTYsi vous essayez echo "hello" | docker run -it alpine catcar dans ce cas, l'entrée en docker runelle-même est le canal de l'écho précédent et non le terminal où docker runest exécuté
Enfin, pourquoi auriez-vous besoin de réussir -tsi vous réussissez à -iconnecter votre entrée à celle catde? En effet, les commandes traitent l'entrée différemment s'il s'agit d'un terminal. Ceci est également mieux illustré par l'exemple
docker run -e MYSQL_ROOT_PASSWORD=123 -i mariadb mysql -u root -pvous donnera une invite de mot de passe. Si vous saisissez le mot de passe, les caractères sont imprimés visiblement.
docker run -i alpine shvous donnera une ligne vide. Si vous tapez une commande comme si lsvous obteniez une sortie, mais vous n'obtiendrez pas une invite ou une sortie colorée.
Dans les deux derniers cas, vous obtenez ce comportement parce mysqlque vous shellne traitez pas l'entrée comme un tty et n'utilisez donc pas de comportement spécifique au tty comme masquer l'entrée ou colorer la sortie.
-itdrapeaux.