Maison > Article > Opération et maintenance > Comment créer un cluster de conteneurs MySQL hautement disponible sous Linux ?
Comment créer un cluster de conteneurs MySQL hautement disponible sous Linux ?
Avec l'essor du cloud computing et de la technologie des conteneurs, de plus en plus d'entreprises commencent à utiliser des conteneurs pour créer des applications. En tant que base de données relationnelle les plus couramment utilisées, MySQL peut également atteindre une haute disponibilité grâce à la conteneurisation. Dans cet article, nous présenterons comment créer un cluster de conteneurs MySQL hautement disponible sur Linux et fournirons des exemples de code pertinents.
Étape 1 : Préparez l'environnement
Tout d'abord, vous avez besoin d'un hôte Linux pour créer un cluster de conteneurs MySQL. Assurez-vous que Docker et Docker Compose sont installés sur cet hôte. S'il n'est pas installé, vous pouvez l'installer avec la commande suivante :
$ sudo apt-get update $ sudo apt-get install docker.io $ sudo apt-get install docker-compose
Étape 2 : Créer une image Docker
Ensuite, vous devez créer une image MySQL pour exécuter le conteneur. Le processus de création d'image peut être défini via Dockerfile. Créez un fichier nommé Dockerfile
et ajoutez-y le contenu suivant : Dockerfile
的文件,并在其中添加以下内容:
FROM mysql:8.0 ENV MYSQL_ROOT_PASSWORD your_password ENV MYSQL_DATABASE your_database COPY your_script.sql /docker-entrypoint-initdb.d/
在上述代码中,your_password
为MySQL的root用户密码,your_database
为要创建的数据库名称,your_script.sql
为要执行的初始化脚本文件。可以根据实际情况修改这些参数。
保存并退出文件后,使用以下命令来构建镜像:
$ sudo docker build -t your_image_name .
其中,your_image_name
是你给镜像起的名称。
步骤三:创建Docker Compose文件
在搭建MySQL容器集群之前,需要创建一个docker-compose.yml
文件来定义集群中的容器。创建一个名为docker-compose.yml
的文件,并在其中添加以下内容:
version: '3' services: mysql1: image: your_image_name restart: always ports: - 3306:3306 volumes: - ./mysql1:/var/lib/mysql environment: - MYSQL_REPLICATION_MODE=master - MYSQL_REPLICATION_USER=repl_user - MYSQL_REPLICATION_PASSWORD=repl_password mysql2: image: your_image_name restart: always volumes: - ./mysql2:/var/lib/mysql environment: - MYSQL_REPLICATION_MODE=slave - MYSQL_MASTER_HOST=mysql1 - MYSQL_MASTER_PORT=3306 - MYSQL_MASTER_USER=repl_user - MYSQL_MASTER_PASSWORD=repl_password
在上述代码中,your_image_name
是之前构建的MySQL镜像名称。mysql1
和mysql2
分别表示两个MySQL容器的名称。MYSQL_REPLICATION_MODE
参数设置容器的复制模式,master
表示主节点,slave
表示从节点。MYSQL_REPLICATION_USER
和MYSQL_REPLICATION_PASSWORD
为复制用户的用户名和密码。MYSQL_MASTER_HOST
和MYSQL_MASTER_PORT
为主节点的地址和端口。MYSQL_MASTER_USER
和MYSQL_MASTER_PASSWORD
为连接主节点的用户名和密码。
步骤四:启动容器集群
保存并退出文件后,使用以下命令来启动容器集群:
$ sudo docker-compose up -d
通过-d
参数可使容器在后台运行。
步骤五:验证容器状态
使用以下命令可以查看容器的状态:
$ sudo docker-compose ps
可以看到容器的状态是running
,表示容器运行正常。
步骤六:测试容器集群
现在,可以测试MySQL容器集群是否正常工作。首先,连接到MySQL容器的主节点,并创建一个测试数据库:
$ sudo docker exec -it mysql1 mysql -uroot -p Enter password: your_password mysql> CREATE DATABASE test; mysql> EXIT;
然后,连接到从节点,并验证是否能够读取到主节点上的数据:
$ sudo docker exec -it mysql2 mysql -uroot -p Enter password: your_password mysql> USE test; mysql> SELECT * FROM your_table; mysql> EXIT;
其中,your_table
rrreee
your_password
est le mot de passe de l'utilisateur root de MySQL, your_database
code> est le nom de la base de données à créer et votre_script.sql
est le fichier de script d'initialisation à exécuter. Ces paramètres peuvent être modifiés en fonction des conditions réelles. Après avoir enregistré et quitté le fichier, utilisez la commande suivante pour créer l'image : rrreee
oùvotre_nom_image
est le nom que vous avez donné à l'image. 🎜🎜Étape 3 : Créer un fichier Docker Compose🎜🎜Avant de créer un cluster de conteneurs MySQL, vous devez créer un fichier docker-compose.yml
pour définir les conteneurs dans le cluster. Créez un fichier appelé docker-compose.yml
et ajoutez-y le contenu suivant : 🎜rrreee🎜Dans le code ci-dessus, your_image_name
est le nom de l'image MySQL créée précédemment. mysql1
et mysql2
représentent respectivement les noms de deux conteneurs MySQL. Le paramètre MYSQL_REPLICATION_MODE
définit le mode de réplication du conteneur, master
représente le nœud maître et slave
représente le nœud esclave. MYSQL_REPLICATION_USER
et MYSQL_REPLICATION_PASSWORD
sont le nom d'utilisateur et le mot de passe de l'utilisateur de réplication. MYSQL_MASTER_HOST
et MYSQL_MASTER_PORT
sont les adresses et les ports du nœud maître. MYSQL_MASTER_USER
et MYSQL_MASTER_PASSWORD
sont le nom d'utilisateur et le mot de passe pour se connecter au nœud maître. 🎜🎜Étape 4 : Démarrez le cluster de conteneurs 🎜🎜Après avoir enregistré et quitté le fichier, utilisez la commande suivante pour démarrer le cluster de conteneurs : 🎜rrreee🎜Le paramètre -d
peut être utilisé pour faire fonctionner le conteneur en arrière-plan. 🎜🎜Étape 5 : Vérifier l'état du conteneur 🎜🎜Utilisez la commande suivante pour vérifier l'état du conteneur : 🎜rrreee🎜Vous pouvez voir que l'état du conteneur est running
, ce qui signifie que le conteneur est en cours d'exécution normalement. 🎜🎜Étape 6 : Testez le cluster de conteneurs🎜🎜Maintenant, vous pouvez tester si le cluster de conteneurs MySQL fonctionne correctement. Tout d'abord, connectez-vous au nœud maître du conteneur MySQL et créez une base de données de test : 🎜rrreee🎜 Ensuite, connectez-vous au nœud esclave et vérifiez si les données sur le nœud maître sont lisibles : 🎜rrreee🎜 Parmi eux, votre_table
est le nom de la table que vous avez créée sur le nœud principal. 🎜🎜Grâce aux étapes ci-dessus, un cluster de conteneurs MySQL hautement disponible a été créé avec succès. En répliquant les données du nœud maître sur plusieurs nœuds esclaves, la redondance des données et la haute disponibilité peuvent être obtenues. Si le nœud maître tombe en panne, un nouveau nœud maître peut être élu parmi les nœuds esclaves et continuer à fournir des services. 🎜🎜J'espère que cet article pourra vous aider à créer un cluster de conteneurs MySQL hautement disponible sur Linux. Je vous souhaite du succès ! 🎜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!