Maison >développement back-end >Golang >construire Golang du cluster Dokcer
Dans le domaine du cloud computing, la technologie des conteneurs est privilégiée pour sa légèreté, son fonctionnement rapide, sa portabilité et son efficacité. En tant que représentant de la technologie des conteneurs, Docker est devenu un outil populaire dans le cloud computing, le DevOps et d'autres domaines en fournissant un moyen léger de packager et de déployer des applications. Pour les applications d'entreprise, les clusters Docker sont nécessaires pour obtenir une haute disponibilité, une mise à l'échelle élastique et d'autres fonctions. Cet article explique comment utiliser Golang pour créer un cluster Docker.
1. Présentation du cluster Docker
Le cluster Docker fait référence à plusieurs hôtes Docker coopérant les uns avec les autres pour réaliser des fonctions telles que le déploiement, la gestion et la surveillance d'applications. Les clusters Docker se composent généralement des concepts de base suivants :
L'hôte Docker fait référence à un ordinateur ou une machine virtuelle exécutant le moteur Docker. Chaque hôte Docker peut déployer et exécuter plusieurs conteneurs Docker.
Docker Swarm est un outil d'orchestration de conteneurs officiellement fourni par Docker. Il peut gérer des conteneurs sur plusieurs hôtes Docker et mettre en œuvre le déploiement et la gestion d'applications en définissant des concepts tels que les services et les tâches.
Service est un groupe de conteneurs dans un cluster Docker avec des fonctions et des spécifications communes, telles que des services Web, des services de base de données, etc. Le service peut définir plusieurs instances de réplica pour réaliser des fonctions telles que la haute disponibilité et l'équilibrage de charge.
Task est une instance de Service, c'est-à-dire un conteneur exécuté sur un certain hôte Docker. Les tâches peuvent être planifiées et gérées par Docker Swarm pour réaliser un déploiement et une gestion automatisés des conteneurs.
Node est un hôte Docker dans un cluster Docker et peut exécuter plusieurs tâches et services.
2. Golang implémente Docker Swarm
Docker Swarm fournit des outils API et CLI RESTful pour gérer et contrôler les clusters Docker. En tant que langage de programmation multiplateforme efficace et simultané, Golang est largement utilisé dans la programmation système et la programmation réseau. Ce qui suit décrit comment utiliser Golang pour implémenter les fonctions de base de Docker Swarm.
Docker SDK for Golang est le client officiel fourni par Docker et peut facilement communiquer avec le serveur Docker. Le SDK Docker pour Golang peut être installé à l'aide de la commande suivante :
go get -u github.com/docker/docker/client
L'API Docker Swarm peut être appelée via des requêtes HTTP et renvoie des données au format JSON. Nous pouvons utiliser Golang pour encapsuler l'API Docker Swarm pour des appels rapides et pratiques. Par exemple, définissez la structure suivante :
type SwarmClient struct { cli *client.Client ctx context.Context } type SwamService struct { ID string `json:"ID"` Name string `json:"Name"` Endpoint Endpoint `json:"Endpoint"` } type Endpoint struct { Spec EndpointSpec `json:"Spec"` } type EndpointSpec struct { Ports []PortConfig `json:"Ports"` } type PortConfig struct { Protocol string `json:"Protocol"` TargetPort uint32 `json:"TargetPort"` PublishedPort uint32 `json:"PublishedPort"` }
Nous pouvons utiliser le package HTTP de Golang pour implémenter les opérations de requête HTTP correspondantes telles que GET, POST, PUT et DELETE.
En plus d'utiliser les appels API RESTful, nous pouvons également implémenter l'outil CLI Docker Swarm pour faciliter la gestion et le fonctionnement du cluster Docker Swarm de manière plus intuitive. Par exemple, implémentez la commande suivante :
docker-swarm service create [OPTIONS] IMAGE [COMMAND] [ARG...]
Cette commande peut créer un service Service en utilisant les paramètres d'image et de commande spécifiés. Nous pouvons utiliser Golang pour implémenter les opérations correspondantes, par exemple :
func createService(image string, command []string, port uint32) { service := &swarm.ServiceSpec{ TaskTemplate: swarm.TaskSpec{ ContainerSpec: swarm.ContainerSpec{ Image: image, Command: command, Env: []string{"PORT=" + strconv.Itoa(int(port))}, }, }, EndpointSpec: &swarm.EndpointSpec{ Ports: []swarm.PortConfig{ swarm.PortConfig{ Protocol: swarm.PortConfigProtocolTCP, TargetPort: uint32(port), PublishedPort: uint32(port), }, }, }, } cli, ctx := initCli() serviceCreateResponse, err := cli.ServiceCreate(ctx, *service, types.ServiceCreateOptions{}) if err != nil { panic(err) } }
Cette fonction peut utiliser Docker SDK pour Golang pour créer un service Service et spécifier des paramètres tels que l'image, la commande et le port.
Pendant le fonctionnement du cluster Docker Swarm, nous devons le surveiller en temps réel et afficher les journaux. Nous pouvons utiliser Golang pour implémenter les programmes correspondants et obtenir l'état du cluster et les journaux des conteneurs en utilisant l'API fournie dans Docker SDK pour Golang. Par exemple :
func listServices() { cli, ctx := initCli() services, err := cli.ServiceList(ctx, types.ServiceListOptions{}) if err != nil { panic(err) } for _, service := range services { fmt.Printf("[Service] ID:%s Name:%s ", service.ID, service.Spec.Name) } } func getServiceLogs(serviceID string) { cli, ctx := initCli() reader, err := cli.ServiceLogs(ctx, serviceID, types.ContainerLogsOptions{}) if err != nil { panic(err) } defer reader.Close() scanner := bufio.NewScanner(reader) for scanner.Scan() { fmt.Println(scanner.Text()) } }
Le code ci-dessus implémente des opérations telles que l'obtention de la liste des services dans le cluster Docker Swarm et l'obtention des journaux du service spécifié.
3. Utilisez Docker Compose pour implémenter le cluster Docker Swarm
Docker Compose est un outil d'orchestration de conteneurs fourni par Docker, qui peut gérer plusieurs conteneurs et services en définissant des fichiers de composition. Nous pouvons utiliser Docker Compose pour créer et gérer rapidement des clusters Docker Swarm. Par exemple, définissez le fichier de composition suivant :
version: '3' services: web: image: nginx deploy: mode: replicated replicas: 3 resources: limits: cpus: "0.1" memory: 50M reservations: cpus: "0.05" memory: 30M restart_policy: condition: on-failure delay: 5s max_attempts: 3 ports: - "80:80" networks: - webnet visualizer: image: dockersamples/visualizer:stable ports: - "8080:8080" stop_grace_period: 30s volumes: - /var/run/docker.sock:/var/run/docker.sock deploy: placement: constraints: [node.role == manager] networks: - webnet networks: webnet:
Ce fichier de composition définit un service Web et un outil de visualisation, utilisant l'image nginx et l'image dockersamples/visualizer comme services. Parmi eux, le mode d'utilisation du service Web est la méthode de déploiement de service répliqué, qui utilisera 3 instances de réplique et définira les limites des ressources CPU et mémoire, la politique de redémarrage et d'autres configurations. L'outil de visualisation utilise le nœud hôte Docker avec node.role comme gestionnaire comme nœud de déploiement pour afficher facilement l'état du cluster Docker Swarm.
Nous pouvons utiliser la commande suivante pour démarrer Docker Compose :
docker stack deploy -c docker-compose.yml webapp
Cette commande créera les instances de service et de tâche correspondantes en fonction des éléments de configuration définis dans le fichier de composition et démarrera le cluster Docker Swarm. Nous pouvons afficher l'état en temps réel du cluster Docker Swarm en accédant à http://localhost:8080.
Résumé
Cet article explique comment utiliser Golang pour implémenter les fonctions de base d'un cluster Docker Swarm et comment utiliser Docker Compose pour créer et gérer rapidement un cluster Docker Swarm. Dans les applications pratiques, les clusters Docker Swarm peuvent fournir une haute disponibilité, une mise à l'échelle élastique et d'autres fonctions, et peuvent permettre une gestion et un déploiement efficaces d'applications conteneurisées.
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!