Démarrage rapide de Docker, concepts de base et instructions communes
Un ami a posé des questions sur Docker au cours du week-end. Aujourd'hui, je vais partager avec vous un démarrage rapide avec Docker, les concepts de base et les instructions communes.
1. Concepts et opérations de base
1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. L'installation de Docker sous CentOS nécessite la version de distribution 7 et supérieure. Il est recommandé d'utiliser le pilote de stockage overlay2. # 卸载已有 docker
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
# 添加安装源
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
# 安装最新版
sudo yum install docker-ce docker-ce-cli containerd.io
# 启动
sudo yum install docker-ce docker-ce-cli containerd.io
Copier après la connexion
# 卸载已有 docker sudo yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine # 添加安装源 sudo yum-config-manager \ --add-repo \ https://download.docker.com/linux/centos/docker-ce.repo # 安装最新版 sudo yum install docker-ce docker-ce-cli containerd.io # 启动 sudo yum install docker-ce docker-ce-cli containerd.io
1.2, image
est essentiellement une combinaison en lecture seule de fichiers et de dossiers, contenant tous les fichiers de base et les informations de configuration requises lors de l'exécution du conteneur. Opération : 1. Tirez sur la tirette du docker d'image. Tels que : docker pull nginx2, renommez la balise docker de l'image Par exemple : docker tag nginx:latest mynginx:latest
3. Affichez l'image docker image ls ou docker images4 Supprimez l'image docker rmiPar exemple : docker rmi mynginx5. ou docker commit Par exemple : docker commit nginx mynginx:lastest La construction de Docker est relativement complexe, mais elle est davantage utilisée
1.3. Conteneur
Le conteneur est l'entité en cours d'exécution de l'image. Une image peut créer plusieurs conteneurs. L'essence de l'exécution d'un conteneur est de créer une copie en lecture-écriture du système de fichiers à l'intérieur du conteneur.
Cycle de vie :
créé : état de construction initial
en cours d'exécution : état en cours d'exécution
arrêté : état arrêté
pause : état en pause
supprimé : état supprimé
Opérations : 1. Créer et démarrer le conteneur
Créer : docker create -it --name=mynginx mynginx
Démarrer : docker start mynginx
Créer et démarrer : docker run -it --name=mynginx mynginx
2 Terminez le conteneur. docker stop mynginx
3. Entrez dans le conteneur. docker attacher mynginx docker exec -it mynginx sh (utilisé davantage)
4. Supprimez le conteneur. docker rm mynginx Supprimez le conteneur en cours d'exécution : docker rm -f mynginx
5. Exportez le conteneur. docker export mynginx > mynginx.tar
6. docker import mynginx.tar mynginx:import
1.4, Warehouse
stocke et distribue les images Docker ; le serveur d'enregistrement est le serveur réel sur lequel l'entrepôt est stocké et peut contenir de nombreux entrepôts, et chaque entrepôt peut contenir plusieurs images.
Hub Docker d'entrepôt public https://hub.docker.com/ Connexion : connexion Docker Poussez l'image vers l'entrepôt : docker push
Utilisez la distribution pour construire un entrepôt privé https://github.com/distribution/distribution
docker run -d -p 5000:5000 --name registre de registre :2.7 docker push localhost : 5000/mynginx
1.5, le volume
peut contourner le système de fichiers commun par défaut et exister directement sur l'hôte sous forme de fichiers ou de répertoires. Il résout les problèmes de persistance des données et de partage de données entre conteneurs. Opération : 1. Créer : docker volume create volume-name
2. -v spécifie le chemin à conserver. Docker créera automatiquement le volume pour nous et le liera au conteneur. docker run -d --name=nginx-volume -v /usr/share/nginx/html nginx
3 Vue : docker volume ls
4 Détails du volume : docker volume inspect volume-name
5. Le paramètre -mount spécifie le nom du volume docker run -d --name=nginx --mount source=volume-name,target=/usr/share/nginx/html nginx
6 Supprimer les volumes : docker volume rm volume-name
7. : docker run --mount source=lv,target=/tmp/log --name=v-producter -it test docker run -it --name consumer --volumes-from v-producer test
8 Partage de données entre volumes et hôtes : docker run -v /data:/usr/local/data -it test
1.6. . Composants importants
1. Docker
docker, est le client Docker, envoie les requêtes dockerd, l'entrée du serveur, est responsable de la réception des requêtes et du retour des résultats docker-init, conteneur Process n°1, gère les sous-conteneurs docker-proxy, transmet le trafic réseau de l'hôte vers le conteneur 2, containersd
containerd, est responsable de la gestion du cycle de vie du conteneur, tels que le démarrage, l'arrêt du conteneur, etc... containerd-shim, en tant que processus parent du processus conteneur, dissocie conteneurd du processus conteneur réel ctr, le client de conteneurd, envoie des requêtes à conteneurd pendant le développement et le débogage 3.
runc, via l'interface système, crée et détruit des conteneurs
1.7, surveillance des conteneurs
Les statistiques Docker peuvent afficher le processeur, la mémoire, les E/S réseau, les E/S disque, le PID, etc. tous les conteneurs sur l’hôte. Utilisation des ressources. cAdvisor est une solution générale de surveillance des conteneurs open source par Google. Référence d'installation :
https://www.jianshu.com/p/91f9d9ec374f
Voir la surveillance : http://localhost:8080 http://localhost:8080/containers/ http://localhost:8080/docker/
1.8, problèmes de sécurité
Vulnérabilités d'auto-sécurité Il y a des problèmes de sécurité dans l'image L'isolation du noyau de l'hôte Linux est pas assez
2. Principe de mise en œuvre
2.1 Namespace
Namespace est une fonctionnalité du noyau Linux qui peut être implémentée dans le même système hôte pour traiter l'ID, nom d'hôte, utilisateur, nom de fichier, communication réseau et inter-processus et autre isolation des ressources.
Docker utilise six types : Mount Namespace, isolation du point de montage Espace de noms PID, isolation des processus Espace de noms UTS, isolation du nom d'hôte Espace de noms IPC, isolation des communications inter-processus Espace de noms d'utilisateur, isolation des utilisateurs et des groupes d'utilisateurs Net Namespace, périphérique réseau, adresse IP et isolation de port
2.2, Cgroups
limitent les ressources d'un processus ou d'un groupe de processus, telles que le processeur, la mémoire, les E/S disque, etc. Fonctions des groupes de contrôle :
"Limiter l'utilisation des ressources"
- 2.3, Union File System
- Il existe trois systèmes de fichiers union les plus couramment utilisés dans Docker : AUFS, Devicemapper et OverlayFS.
Union File System, un système de fichiers léger en couches qui peut monter conjointement le contenu de plusieurs répertoires dans le même répertoire pour former un seul système de fichiers. - AUFS est le plus ancien et le plus mature ;
overlay2, la mise à jour est plus stable et adaptée au noyau Linux et à la version Docker ; les exigences sont relativement élevées.
- 2.4. Implémentation du réseau
- Libnetwork contient quatre modèles de réseau principaux :
CNM (Container Network Model) est une norme de réseau de conteneurs publiée par Docker. Libnetwork est open source, écrit en Golang, suit entièrement les spécifications du réseau CNM et constitue l'implémentation officielle de CNM.
mode réseau nul, aucun réseau de conteneurs n'est fourni mode pont pont, les conteneurs peuvent communiquer entre eux mode réseau hôte hôte, le conteneur peut communiquer avec le réseau hôte réseau de conteneurs mode, conteneur Mis sur le même réseau via des interviews LocalHost
3, autres connexes
3.1, disposition des conteneurs
Docker : Docker Compose, Docker Swarm, Kubernetes .Docker Compose a été acquis par Docker. Il s'agit essentiellement d'un script python qui peut gérer et orchestrer plusieurs conteneurs sur un seul nœud.
- Docker Swarm est un outil de gestion de cluster de conteneurs officiellement lancé par Docker. Il prend en charge nativement l'API Docker, prend en charge l'authentification bidirectionnelle TLS et utilise le protocole Raft pour réaliser la distribution.
- Kubernetes, Google s'appuie sur la conception technique et la mise en œuvre accumulée par le système interne Borg. Il est puissant et vise à supporter le fonctionnement de centaines de millions de conteneurs cependant, son architecture est relativement complexe et le seuil de démarrage ; est élevé.
3.2. Le rôle dans le DevOps
L'objectif global du DevOps est de promouvoir la coopération entre le personnel de développement et d'exploitation et de maintenance, et de raccourcir l'ensemble du cycle de livraison des logiciels par des moyens automatisés et d'améliorer les logiciels. qualité.Installez rapidement l'environnement de développement via Docker, intégrez rapidement Dockerfile pour créer des images, extrayez l'image et exécutez le conteneur pour terminer le déploiement, et combinez-le avec des outils d'orchestration de conteneurs pour obtenir une version bleu-vert.
Favorise le développement de DevOps.
Permet une intégration et une livraison continues et rapides.
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.

La conteneurisation améliore les performances des fonctions Java des manières suivantes : Isolation des ressources : garantit un environnement informatique isolé et évite les conflits de ressources. Léger - consomme moins de ressources système et améliore les performances d'exécution. Démarrage rapide - réduit les délais d'exécution des fonctions. Cohérence : dissociez les applications et l'infrastructure pour garantir un comportement cohérent dans tous les environnements.

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.
