Qu'est-ce que l'orchestration des conteneurs Docker
Dans Docker, en exécutant un fichier YAML, plusieurs conteneurs définis dans le fichier sont démarrés en séquence. Il s'agit de l'orchestration de conteneurs ; l'outil d'implémentation de l'orchestration de conteneurs est "docker-compose". Le fichier YAML définit une série de conteneurs et de propriétés d'exécution du conteneur, et Compose gérera le conteneur en fonction de ces configurations.
L'environnement d'exploitation de ce tutoriel : système linux5.9.8, version docker-1.13.1, ordinateur Dell G3.
Orchestration de conteneurs Docker
Qu'est-ce que l'orchestration de conteneurs
- En exécutant un fichier, plusieurs conteneurs définis dans le fichier sont démarrés en séquence
- Ce fichier est un fichier yaml
Outils utilisés. pour l'orchestration de conteneurs
-
docker-compose
Vous pouvez implémenter une orchestration de conteneurs basée sur des fichiers YAML en installant l'outil Docker Compose. Les fichiers YAML définiront une série de conteneurs et les attributs d'exécution du conteneur Docker Compose utiliseront ces configurations. gérer les conteneurs.
Installer docker-compose
- docker-compose dans la source epel
[root@worker1 ~]# yum install epel-release -y [root@worker1 ~]# yum install docker-compose -y
Utilisation de la commande docker-compose
Format : docker-compose [options]
Options
- up : Démarrez le conteneur défini dans le fichier yaml
- down : Fermez le conteneur défini dans le fichier yaml
- -f x.yaml : Spécifiez le fichier yaml à lire par docker-compose
- -d : Dans le background Exécuter l'opération
- ps : Vérifiez l'état du conteneur démarré en fonction de docker-compose
- logs : Vérifiez les informations du journal pendant le processus de démarrage du conteneur, utilisées pour dépanner les erreurs
Cas :
write docker-compose .yaml fichier pour démarrer deux conteneurs: nginx, php
1) Préparez l'environnement
- install epel
- install docker-compose
- restart docker
- restart the Firewall
[root@master ~]# yum install docker -y [root@master ~]# yum install epel-release -y [root@master ~]# yum install docker-compose -y [root@master ~]# systemctl restart docker [root@master ~]# systemctl restart firewalld
2) Créer un fichier yaml
# 编写yam文件,在文件实现自动启动nginx容器 [root@worker1 ~]# vim docker-compose.yaml
version: '2' services: web: image: nginx:1.17.10 ports: - 80:80 volumes: - /opt/html:/web - /opt/conf/nginx.conf:/etc/nginx/nginx.conf
- version : Spécifiez le numéro de version, 2
- services : Défini pour démarrer le service, un service est un conteneur Docker
2) nginx démarre le conteneur
[root@worker1 ~]# docker-compose up -d
Afficher l'état du conteneur démarré en fonction du fichier yaml
[root@master ~]# docker-compose ps Name Command State Ports -------------------------------------------------------------- root_web_1 nginx -g daemon off; Up 0.0.0.0:80->80/tcp
- L'état est principalement état : s'il est UP, cela signifie normal
Afficher les informations du journal pendant le processus de démarrage du conteneur
[root@worker1 ~]# docker-compose logs
Fermez le conteneur démarré en fonction du fichier yaml
[root@worker1 ~]# docker-compose down
3) dans Sur la base de la deuxième étape, modifiez le fichier yaml et démarrez le service php
La première étape : modifier le fichier yaml
version: '2'services: web: image: nginx ports: - 80:80 volumes: - /opt/html:/web - /opt/conf/nginx.conf:/etc/nginx/nginx.conf links: # 指定php容器的名称 - php php: # 此处需要和links中的值保持一致 image: php:5.6-fpm container_name: php # 此处需要和links中的值保持一致 volumes: - /opt/php:/php
La deuxième étape : Modifier le fichier de configuration nginx
[root@master ~]# vi /opt/conf/nginx.conf location ~ \.php$ { root /php; fastcgi_pass php:9000; # 指定php容器名称,docker会自动将名称转换成ip fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
La troisième étape : Démarrer le service
[root@master ~]# docker-compose up -d [root@master ~]# docker-compose ps Name Command State Ports ----------------------------------------------------------------------- php docker-php-entrypoint php-fpm Up 9000/tcp root_web_1 nginx -g daemon off; Up 0.0.0.0:80->80/tcp
Application d'orchestration de conteneurs question 1
1 Préparez un serveur Centos7 et vérifiez que le réseau est normal
2 Vérifiez si le docker du serveur fonctionne normalement. Sinon, veuillez l'installer
3 Veuillez écrire Le fichier modèle wordpress.yml est au bon format
4 Veuillez créer de nouveaux services mysql et wordpress Le démarrage. de wordpress dépend du service mysql
5 Montez le répertoire /opt/wordpress/data dans le répertoire /var/lib/mysql du conteneur mysql Ensuite, créez un stockage persistant !
6 Les informations initiales de MySQL incluent : le mot de passe root, la base de données créée, l'utilisateur ordinaire, le mot de passe de l'utilisateur ordinaire
7 La configuration de la base de données WordPress est correcte
8 WordPress effectue le mappage des ports, mappant le port 80 de wordprss au port 8000 de l'hôte
# 这个yaml文件要启动两个容器 version: '2' services: # 第一个容器:wordpress容器 wordpress: # 指定镜像名称 image: wordpress # 将容器的80端口映射到宿主机的8000 ports: - 8000:80 # 设置将mysql容器的名称解析程序mysql容器的IP links: - mysql # 设置容器之间依赖关系,设置成必须先启动mysql容器才启动wordpress容器 depends_on: - mysql # 第二个容器:MySQL容器 mysql: # 指定镜像名名称是mysql image: mysql:5.6 # 设置容器的名称的是mysql container_name: mysql # 设置逻辑卷挂载 volumes: - /opt/wordpress/data:/var/lib/mysql # 设置mysql容器的环境变量 environment: # 设置mysql容器中mysql的root密码为123 MYSQL_ROOT_PASSWORD: 123 # 为wordpress创建一个数据库,库名是wordpress MYSQL_DATABASE: wp # 创建一个普通用户wp MYSQL_USER: wp # 为上面的普通用户设置密码是wp MYSQL_PASSWORD: wp
9 docker-compose a démarré avec succès chaque conteneur et accédé avec succès à la page wordpress
[root@master ~]# docker-compose up -d [root@master ~]# docker ps
- Accès au navigateur : http://ip:8000
Apprentissage recommandé : "Tutoriel vidéo docker"
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

L'architecture système distribuée PHP atteint l'évolutivité, les performances et la tolérance aux pannes en distribuant différents composants sur les machines connectées au réseau. L'architecture comprend des serveurs d'applications, des files d'attente de messages, des bases de données, des caches et des équilibreurs de charge. Les étapes de migration des applications PHP vers une architecture distribuée comprennent : Identifier les limites des services Sélectionner un système de file d'attente de messages Adopter un cadre de microservices Déploiement vers la gestion de conteneurs Découverte de services

Réponse : Les microservices PHP sont déployés avec HelmCharts pour un développement agile et conteneurisés avec DockerContainer pour l'isolation et l'évolutivité. Description détaillée : utilisez HelmCharts pour déployer automatiquement des microservices PHP afin de réaliser un développement agile. Les images Docker permettent une itération rapide et un contrôle de version des microservices. Le standard DockerContainer isole les microservices et Kubernetes gère la disponibilité et l'évolutivité des conteneurs. Utilisez Prometheus et Grafana pour surveiller les performances et l'état des microservices, et créer des alarmes et des mécanismes de réparation automatiques.

Explication détaillée et guide d'installation pour les nœuds de pignon Cet article introduira l'écosystème de pignon en détail - nœuds PI, un rôle clé dans l'écosystème de pignon et fournir des étapes complètes pour l'installation et la configuration. Après le lancement du réseau de test de la blockchain pèse, les nœuds PI sont devenus une partie importante de nombreux pionniers participant activement aux tests, se préparant à la prochaine version du réseau principal. Si vous ne connaissez pas encore Pinetwork, veuillez vous référer à ce qu'est Picoin? Quel est le prix de l'inscription? PI Utilisation, exploitation minière et sécurité. Qu'est-ce que Pinetwork? Le projet Pinetwork a commencé en 2019 et possède sa pièce exclusive de crypto-monnaie PI. Le projet vise à en créer un que tout le monde peut participer

Il existe de nombreuses façons d'installer Deepseek, notamment: Compiler à partir de Source (pour les développeurs expérimentés) en utilisant des packages précompilés (pour les utilisateurs de Windows) à l'aide de conteneurs Docker (pour le plus pratique, pas besoin de s'inquiéter de la compatibilité), quelle que soit la méthode que vous choisissez, veuillez lire Les documents officiels documentent soigneusement et les préparent pleinement à éviter des problèmes inutiles.

Réponse : Utilisez PHPCI/CD pour réaliser une itération rapide, y compris la configuration de pipelines CI/CD, de tests automatisés et de processus de déploiement. Configurer un pipeline CI/CD : sélectionnez un outil CI/CD, configurez le référentiel de code et définissez le pipeline de build. Tests automatisés : rédigez des tests unitaires et d'intégration et utilisez des frameworks de test pour simplifier les tests. Cas pratique : Utilisation de TravisCI : Installez TravisCI, définissez le pipeline, activez le pipeline et visualisez les résultats. Mettez en œuvre la livraison continue : sélectionnez les outils de déploiement, définissez les pipelines de déploiement et automatisez le déploiement. Avantages : améliorez l’efficacité du développement, réduisez les erreurs et raccourcissez les délais de livraison.

Déployez des applications Java EE à l'aide de conteneurs Docker : créez un fichier Docker pour définir l'image, créez l'image, exécutez le conteneur et mappez le port, puis accédez à l'application dans le navigateur. Exemple d'application JavaEE : l'API REST interagit avec la base de données, accessible sur localhost après déploiement via Docker.

1. Tout d'abord, après avoir ouvert l'interface, cliquez sur le bouton icône d'extension à gauche 2. Ensuite, recherchez l'emplacement de la barre de recherche dans la page d'extension ouverte 3. Ensuite, entrez le mot Docker avec la souris pour trouver le plug-in d'extension 4. . Enfin, sélectionnez le plug-in cible et cliquez à droite. Cliquez simplement sur le bouton d'installation dans le coin inférieur.

L'architecture des microservices utilise des frameworks PHP (tels que Symfony et Laravel) pour implémenter des microservices et suit les principes RESTful et les formats de données standard pour concevoir des API. Les microservices communiquent via des files d'attente de messages, des requêtes HTTP ou gRPC et utilisent des outils tels que Prometheus et ELKStack pour la surveillance et le dépannage.
