Le but du fichier du plug-in :
Il existe deux façons d'exécuter un conteneur :
- docker run command
- docker-compose command
La méthode de commande docker run utilise le paramètre -v pour monter le répertoire hôte externe sur le chemin dans le conteneur. S'il existe plusieurs points de montage, spécifiez-les via plusieurs. -v, et seuls les chemins absolus peuvent être utilisés ; la commande docker-compose utilise la méthode de service. Pour être précis, un service peut contenir plusieurs conteneurs, et la configuration de montage du chemin externe est également configurée via le. Paramètre -v L'avantage est que vous pouvez utiliser un chemin relatif, qui est bien entendu relatif au chemin du fichier docker-compose.yml. Un autre avantage est que la commande permettant à docker-compose de démarrer le conteneur est relativement simple.
Supposons que la structure du chemin d'empaquetage de l'image est la suivante :
├── build.sh
├── docker-compose.yml
├── Dockerfile
├── mynginx.conf
├── nginx-vol
│ ├── conf.d
│ │ └── mynginx.conf
│ ├── html
│ │ └── index.html
│ └── logs
│ ├── access.log
│ └── error.log
└── run.sh
Copier après la connexion
Dockerfile est le fichier de configuration pour créer l'image et le contenu est le suivant :
FROM nginx
LABEL maintainer="xxx" email="<xxx@xxx.com>" app="nginx test" version="v1.0"
ENV WEBDIR="/data/web/html"
RUN mkdir -p ${WEBDIR}
EXPOSE 5180
Copier après la connexion
Basé sur nginx, spécifiez le nouveau chemin du fichier de données comme /data/ web/html, et le port exposé est 5180.
Compilez une nouvelle image via la commande suivante :
docker build -t nginx:test-v1 .
Copier après la connexion
La balise d'image compilée est test-v1. Vous pouvez voir l'image locale :
docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx test-v1 d2a0eaea3fac 56 minutes ago 141MB
nginx latest 605c77e624dd 9 days ago 141MB
Copier après la connexion
Vous pouvez voir que l'image avec la balise test-v1 est simplement la nouvelle image. compilé.
Créez le volume externe nginx nginx-vol et les dossiers conf.d, logs et html associés, et placez le contenu correspondant dans leurs répertoires correspondants. Par exemple, le contenu de iindex.html dans le dossier html est le suivant :
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<title>系统时间</title>
<body>
<div id="datetime">
<script>
setInterval("document.getElementById('datetime').innerHTML=new Date().toLocaleString();",1000);
</script>
</div>
</body>
</head>
</html>
Copier après la connexion
En fait, c'est juste une page qui affiche l'heure actuelle.
La section des journaux est vide. Le but est d'écrire les journaux lorsque le conteneur est exécuté sur un stockage externe. Même si le conteneur est arrêté ou l'image est détruite, les journaux en cours d'exécution peuvent toujours être conservés.
conf.d ci-dessous est la configuration personnalisée de nginx, le contenu est le suivant :
server {
listen 5180;
#listen [::]:5180;
server_name localhost;
#access_log /var/log/nginx/host.access.log main;
location / {
root /data/web/html;
index index.html index.htm;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#location ~ /\.ht {
# deny all;
}
Copier après la connexion
En fait, le port et le chemin racine sont modifiés en fonction du fichier default.conf par défaut de nginx. Le but est d'illustrer que les fichiers de configuration nginx peuvent également utiliser. stockage externe , si votre propre programme peut modifier le fichier de configuration, vous pouvez ainsi modifier le fichier de configuration pendant l'exécution du conteneur ; le fichier de configuration modifié est en fait stocké sur un stockage externe, il ne disparaîtra donc pas lorsque le conteneur s'arrêtera. en cours d'exécution. Il ne sera pas restauré dans les fichiers contenus dans l'image.
docker run mode
Pour plus de commodité, vous pouvez écrire la commande en cours d'exécution dans un script shell, tel que run.sh, le contenu est le suivant :
docker run --name nginx-v1 -p 15180:5180 -v /home/project/nginx-test/nginx-vol/logs:/var/log/nginx -v /home/project/nginx-test/nginx-vol/conf.d:/etc/nginx/conf.d -v /home/project/nginx-test/nginx-vol/html:/data/web/html -d nginx:test-v1
Copier après la connexion
Vous pouvez voir qu'il y a 3 -v dans la commande, ce qui correspondent à différents montages de stockage externe. Téléchargez et mappez vers différents répertoires dans le conteneur. Les ports après
-p (notez qu'il est en minuscule) sont respectivement le port de l'hôte et le port du conteneur, c'est-à-dire que le port 15180 de l'hôte est mappé au port 5180 du conteneur, de sorte que le port de service nginx 5180 démarré par le conteneur peut accéder au port 15180 de l'hôte et être mappé.
Afficher les conteneurs en cours d'exécution :
docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
cf2275da5130 nginx:test-v1 "/docker-entrypoint.…" 6 seconds ago Up 5 seconds 80/tcp, 0.0.0.0:15180->5180/tcp, :::15180->5180/tcp nginx-v1
Copier après la connexion
Afficher la cartographie détaillée :
docker inspect nginx-v1
Copier après la connexion
affichera des informations complètes, dans la section "Montages", vous pourrez voir la cartographie complète des montages de stockage.
Regardez directement sous nginx-vol/logs sur l'hôte. Vous pouvez voir que le journal en cours d'exécution de nginx dans le conteneur est automatiquement écrit dans le stockage de l'hôte externe.
ls -l nginx-vol/logs/
total 12
-rw-r--r-- 1 root root 1397 1月 8 15:08 access.log
-rw-r--r-- 1 root root 4255 1月 8 15:59 error.log
Copier après la connexion
Arrêter le conteneur :
docker stop nginx-v1
Copier après la connexion
Supprimer le conteneur :
docker rm nginx-v1
Copier après la connexion
docker-compose mode
Installer docker-compose
apt-get install docker-compose
Copier après la connexion
Écrire le fichier docker-compose.yml
version: "3"
services:
nginx:
container_name: mynginx
image: nginx:test-v1
ports:
- 80:5180
volumes:
- ./nginx-vol/html:/data/web/html
- ./nginx-vol/logs:/var/log/nginx
- ./nginx-vol/conf.d:/etc/nginx/conf.d
restart: always
Copier après la connexion
container_name : Spécifiez le nom du conteneur
image : utiliser Miroir et balises correspondantes
ports : mappage du port hôte et du port du conteneur
volumes : mappage du montage du stockage externe
Démarrer le conteneur
docker-compose up -d
Creating network "nginxtest_default" with the default driver
Creating mynginx ...
Creating mynginx ... done
Copier après la connexion
Afficher le conteneur
docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
635e2999c825 nginx:test-v1 "/docker-entrypoint.…" 24 seconds ago Up 22 seconds 80/tcp, 0.0.0.0:80->5180/tcp, :::80->5180/tcp mynginx
Copier après la connexion
Vous pouvez voir que le conteneur s'exécute selon le docker-compose La configuration .yml, le port, le nom et le montage sont tous normaux. L'accès au port 80 de l'hôte correspond au service 5180 du conteneur.
Arrêtez le conteneur
docker-compose down
Stopping mynginx ... done
Removing mynginx ... done
Removing network nginxtest_default
Copier après la connexion
Comme vous pouvez le voir, il est plus facile d'utiliser docker-compose.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!