Maison Java javaDidacticiel Démarrage rapide de Docker, concepts de base et instructions communes

Démarrage rapide de Docker, concepts de base et instructions communes

Aug 23, 2023 pm 02:56 PM
docker


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.

Démarrage rapide de Docker, concepts de base et 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

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 images

4 Supprimez l'image docker rmi

Par exemple : docker rmi mynginx

5. 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
  • 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.
  • Il existe trois systèmes de fichiers union les plus couramment utilisés dans Docker : AUFS, Devicemapper et OverlayFS.
  • AUFS est le plus ancien et le plus mature ;

Devicemapper, un framework fourni par le noyau Linux, est un framework technique pour cartographier les périphériques bloc. Les concepts de base incluent le périphérique mappé, le périphérique cible et la table de mappage, y compris le mode boucle-lvm et le mode direct-lvm (pour une utilisation en production)

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
  • 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.
  • Libnetwork contient quatre modèles de réseau principaux :
    • 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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Architecture et pratique du système distribué PHP Architecture et pratique du système distribué PHP May 04, 2024 am 10:33 AM

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

Développement et exploitation agiles de la conteneurisation de microservices PHP Développement et exploitation agiles de la conteneurisation de microservices PHP May 08, 2024 pm 02:21 PM

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.

Enseignement du nœud PI: Qu'est-ce qu'un nœud PI? Comment installer et configurer le nœud PI? Enseignement du nœud PI: Qu'est-ce qu'un nœud PI? Comment installer et configurer le nœud PI? Mar 05, 2025 pm 05:57 PM

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

Comment installer Deepseek Comment installer Deepseek Feb 19, 2025 pm 05:48 PM

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.

Comment optimiser les performances des fonctions Java grâce à la conteneurisation ? Comment optimiser les performances des fonctions Java grâce à la conteneurisation ? Apr 29, 2024 pm 03:09 PM

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.

Comment utiliser PHP CI/CD pour itérer rapidement ? Comment utiliser PHP CI/CD pour itérer rapidement ? May 08, 2024 pm 10:15 PM

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éployer des applications JavaEE à l'aide de conteneurs Docker Déployer des applications JavaEE à l'aide de conteneurs Docker Jun 05, 2024 pm 08:29 PM

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.

Comment installer l'extension Docker dans vscode Étapes pour installer l'extension Docker dans vscode Comment installer l'extension Docker dans vscode Étapes pour installer l'extension Docker dans vscode May 09, 2024 pm 03:25 PM

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.

See all articles