82 lines
2.3 KiB
Markdown
82 lines
2.3 KiB
Markdown
\newpage
|
||
|
||
Intervenir durant l'exécution
|
||
=============================
|
||
|
||
Lorsque nous lançons un conteneur, il arrive que son comportement nous
|
||
échappe : une imprécision dans la documentation, un cas particulier, une erreur
|
||
de configuration, ... Lorsque le conteneur est en cours d'exécution, il y a
|
||
plusieurs manières de contrôler ce qu'il se passe.
|
||
|
||
|
||
docker logs
|
||
-----------
|
||
|
||
La première étape consiste bien souvent à regarder ce que le conteneur affiche
|
||
sur ses sorties standard et d'erreur. Lorsqu'il est lancé en monde *daemon*, il
|
||
convient d'utiliser la commande :
|
||
|
||
<div lang="en-US">
|
||
```bash
|
||
docker container logs 0a1b2c3d4e
|
||
```
|
||
</div>
|
||
|
||
Cela affichera l'intégralité des journaux depuis la création du conteneur.
|
||
|
||
En ajoutant l'option `--follow` lorsque le conteneur est actif, cela laissera
|
||
la commande active `logs` pour afficher en direct les nouvelles lignes
|
||
inscrites sur les sorties du conteneur.
|
||
|
||
|
||
Entrer dans un conteneur en cours d'exécution
|
||
---------------------------------------------
|
||
|
||
Dans certaines circonstances, les journaux ne sont pas suffisants pour déboguer
|
||
correctement l'exécution d'un conteneur.
|
||
|
||
En réalisant les exercices, vous serez sans doute confronté à des comportements
|
||
étranges, que vous ne pourriez comprendre qu'en ayant la main sur le conteneur,
|
||
à travers un shell.
|
||
|
||
Lorsqu'un conteneur est actif, vous pouvez y lancer un nouveau processus,
|
||
notamment un shell par exemple :
|
||
|
||
<div lang="en-US">
|
||
```bash
|
||
docker container exec -it mycloud /bin/bash
|
||
(inctnr)# hostname
|
||
0a1b2c3d4e5f
|
||
(inctnr)# ping mysql_cntr_name
|
||
...
|
||
```
|
||
</div>
|
||
|
||
On peut aussi imaginer lancer régulièrement une commande par ce biais : pour
|
||
déclencher une sauvegarde d'un conteneur serveur de base de données ou pour
|
||
exécuter une tâche périodique.
|
||
|
||
::::: {.question}
|
||
|
||
Il n'est pas possible d'`exec` dans un conteneur éteint. Aussi, si la commande
|
||
initiale du conteneur se termine, tous les `exec` seront instantanément tués.
|
||
|
||
:::::
|
||
|
||
|
||
docker top
|
||
----------
|
||
|
||
Si plusieurs processus doivent s'exécuter dans un conteneur, un bon moyen de
|
||
savoir s'ils sont tous actifs est d'utiliser :
|
||
|
||
<div lang="en-US">
|
||
```bash
|
||
docker container top cntr_name
|
||
```
|
||
</div>
|
||
|
||
Cela liste tous les processus rattaché au conteneur nommé : à la fois les
|
||
processus démarrés par le `run`, mais également les éventuels processus
|
||
rattachés par `exec`.
|