집 >운영 및 유지보수 >리눅스 운영 및 유지 관리 >Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?
Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?
클라우드 컴퓨팅과 컨테이너 기술의 등장으로 점점 더 많은 기업이 컨테이너를 사용하여 애플리케이션을 구축하기 시작했습니다. 가장 일반적으로 사용되는 관계형 데이터베이스 중 하나인 MySQL은 컨테이너화를 통해 고가용성을 달성할 수도 있습니다. 이 기사에서는 Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법을 소개하고 관련 코드 예제를 제공합니다.
1단계: 환경 준비
먼저 MySQL 컨테이너 클러스터를 구축하려면 Linux 호스트가 필요합니다. Docker 및 Docker Compose가 이 호스트에 설치되어 있는지 확인하세요. 설치되지 않은 경우 다음 명령을 사용하여 설치할 수 있습니다.
$ sudo apt-get update $ sudo apt-get install docker.io $ sudo apt-get install docker-compose
2단계: Docker 이미지 생성
다음으로 컨테이너를 실행할 MySQL 이미지를 생성해야 합니다. 이미지 구축 프로세스는 Dockerfile을 통해 정의할 수 있습니다. Dockerfile
이라는 파일을 생성하고 그 안에 다음 콘텐츠를 추가합니다. 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
는 MySQL의 루트 사용자 비밀번호인 your_database / code>는 생성할 데이터베이스 이름이고, <code>your_script.sql
은 실행할 초기화 스크립트 파일이다. 이러한 매개변수는 실제 조건에 따라 수정될 수 있습니다. 파일을 저장하고 종료한 후 다음 명령을 사용하여 이미지를 빌드합니다. rrreee
여기서your_image_name
은 이미지에 지정한 이름입니다. 🎜🎜3단계: Docker Compose 파일 생성🎜🎜MySQL 컨테이너 클러스터를 구축하기 전에 docker-compose.yml
파일을 생성하여 클러스터의 컨테이너를 정의해야 합니다. docker-compose.yml
이라는 파일을 만들고 그 안에 다음 콘텐츠를 추가합니다. 🎜rrreee🎜위 코드에서 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
는 마스터 노드에 연결하기 위한 사용자 이름과 비밀번호입니다. 🎜🎜4단계: 컨테이너 클러스터 시작 🎜🎜파일을 저장하고 종료한 후 다음 명령을 사용하여 컨테이너 클러스터를 시작합니다. 🎜rrreee🎜-d
매개변수를 사용하여 컨테이너를 실행할 수 있습니다. 백그라운드에서. 🎜🎜5단계: 컨테이너 상태 확인 🎜🎜다음 명령을 사용하여 컨테이너 상태를 확인하세요. 🎜rrreee🎜컨테이너 상태가 running
인 것을 확인할 수 있습니다. 이는 컨테이너가 실행 중임을 의미합니다. 보통. 🎜🎜6단계: 컨테이너 클러스터 테스트🎜🎜이제 MySQL 컨테이너 클러스터가 제대로 작동하는지 테스트할 수 있습니다. 먼저 MySQL 컨테이너의 마스터 노드에 연결하여 테스트 데이터베이스를 생성합니다: 🎜rrreee🎜 그런 다음 슬레이브 노드에 연결하여 마스터 노드의 데이터를 읽을 수 있는지 확인합니다: 🎜rrreee🎜 그 중 your_table code>는 기본 노드에 생성한 테이블의 이름입니다. 🎜🎜위 단계를 통해 가용성이 높은 MySQL 컨테이너 클러스터가 성공적으로 구축되었습니다. 마스터 노드의 데이터를 여러 슬레이브 노드에 복제함으로써 데이터 이중화 및 고가용성을 달성할 수 있습니다. 마스터 노드에 장애가 발생하면 슬레이브 노드에서 새로운 마스터 노드가 선출되어 계속해서 서비스를 제공할 수 있습니다. 🎜🎜이 기사가 Linux에서 가용성이 높은 MySQL 컨테이너 클러스터를 구축하는 데 도움이 되기를 바랍니다. 나는 당신의 성공을 기원합니다! 🎜
위 내용은 Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!