운영 및 유지보수 리눅스 운영 및 유지 관리 Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?

Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?

Aug 01, 2023 am 10:13 AM
mysql 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镜像名称。mysql1mysql2分别表示两个MySQL容器的名称。MYSQL_REPLICATION_MODE参数设置容器的复制模式,master表示主节点,slave表示从节点。MYSQL_REPLICATION_USERMYSQL_REPLICATION_PASSWORD为复制用户的用户名和密码。MYSQL_MASTER_HOSTMYSQL_MASTER_PORT为主节点的地址和端口。MYSQL_MASTER_USERMYSQL_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_tablerrreee

위 코드에서 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 이미지의 이름입니다. mysql1mysql2는 각각 두 개의 MySQL 컨테이너 이름을 나타냅니다. MYSQL_REPLICATION_MODE 매개변수는 컨테이너의 복제 모드를 설정하고, master는 마스터 노드를, slave는 슬레이브 노드를 나타냅니다. MYSQL_REPLICATION_USERMYSQL_REPLICATION_PASSWORD는 복제 사용자의 사용자 이름과 비밀번호입니다. MYSQL_MASTER_HOSTMYSQL_MASTER_PORT는 마스터 노드의 주소와 포트입니다. MYSQL_MASTER_USERMYSQL_MASTER_PASSWORD는 마스터 노드에 연결하기 위한 사용자 이름과 비밀번호입니다. 🎜🎜4단계: 컨테이너 클러스터 시작 🎜🎜파일을 저장하고 종료한 후 다음 명령을 사용하여 컨테이너 클러스터를 시작합니다. 🎜rrreee🎜-d 매개변수를 사용하여 컨테이너를 실행할 수 있습니다. 백그라운드에서. 🎜🎜5단계: 컨테이너 상태 확인 🎜🎜다음 명령을 사용하여 컨테이너 상태를 확인하세요. 🎜rrreee🎜컨테이너 상태가 running인 것을 확인할 수 있습니다. 이는 컨테이너가 실행 중임을 의미합니다. 보통. 🎜🎜6단계: 컨테이너 클러스터 테스트🎜🎜이제 MySQL 컨테이너 클러스터가 제대로 작동하는지 테스트할 수 있습니다. 먼저 MySQL 컨테이너의 마스터 노드에 연결하여 테스트 데이터베이스를 생성합니다: 🎜rrreee🎜 그런 다음 슬레이브 노드에 연결하여 마스터 노드의 데이터를 읽을 수 있는지 확인합니다: 🎜rrreee🎜 그 중 your_table code>는 기본 노드에 생성한 테이블의 이름입니다. 🎜🎜위 단계를 통해 가용성이 높은 MySQL 컨테이너 클러스터가 성공적으로 구축되었습니다. 마스터 노드의 데이터를 여러 슬레이브 노드에 복제함으로써 데이터 이중화 및 고가용성을 달성할 수 있습니다. 마스터 노드에 장애가 발생하면 슬레이브 노드에서 새로운 마스터 노드가 선출되어 계속해서 서비스를 제공할 수 있습니다. 🎜🎜이 기사가 Linux에서 가용성이 높은 MySQL 컨테이너 클러스터를 구축하는 데 도움이 되기를 바랍니다. 나는 당신의 성공을 기원합니다! 🎜

위 내용은 Linux에서 고가용성 MySQL 컨테이너 클러스터를 구축하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Centos와 Ubuntu의 차이 Centos와 Ubuntu의 차이 Apr 14, 2025 pm 09:09 PM

Centos와 Ubuntu의 주요 차이점은 다음과 같습니다. Origin (Centos는 Red Hat, Enterprise의 경우, Ubuntu는 Debian에서 시작하여 개인의 경우), 패키지 관리 (Centos는 안정성에 중점을 둡니다. Ubuntu는 APT를 사용하여 APT를 사용합니다), 지원주기 (Ubuntu는 5 년 동안 LTS 지원을 제공합니다), 커뮤니티에 중점을 둔다 (Centos Conciors on ubuntu). 튜토리얼 및 문서), 사용 (Centos는 서버에 편향되어 있으며 Ubuntu는 서버 및 데스크탑에 적합), 다른 차이점에는 설치 단순성 (Centos는 얇음)이 포함됩니다.

Centos는 유지 보수를 중지합니다. 2024 Centos는 유지 보수를 중지합니다. 2024 Apr 14, 2025 pm 08:39 PM

Centos는 2024 년에 상류 분포 인 RHEL 8이 종료 되었기 때문에 폐쇄 될 것입니다. 이 종료는 CentOS 8 시스템에 영향을 미쳐 업데이트를 계속받지 못하게합니다. 사용자는 마이그레이션을 계획해야하며 시스템을 안전하고 안정적으로 유지하기 위해 Centos Stream, Almalinux 및 Rocky Linux가 포함됩니다.

Centos를 설치하는 방법 Centos를 설치하는 방법 Apr 14, 2025 pm 09:03 PM

CentOS 설치 단계 : ISO 이미지를 다운로드하고 부팅 가능한 미디어를 실행하십시오. 부팅하고 설치 소스를 선택하십시오. 언어 및 키보드 레이아웃을 선택하십시오. 네트워크 구성; 하드 디스크를 분할; 시스템 시계를 설정하십시오. 루트 사용자를 만듭니다. 소프트웨어 패키지를 선택하십시오. 설치를 시작하십시오. 설치가 완료된 후 하드 디스크에서 다시 시작하고 부팅하십시오.

Docker 원리에 대한 자세한 설명 Docker 원리에 대한 자세한 설명 Apr 14, 2025 pm 11:57 PM

Docker는 Linux 커널 기능을 사용하여 효율적이고 고립 된 응용 프로그램 실행 환경을 제공합니다. 작동 원리는 다음과 같습니다. 1. 거울은 읽기 전용 템플릿으로 사용되며, 여기에는 응용 프로그램을 실행하는 데 필요한 모든 것을 포함합니다. 2. Union 파일 시스템 (Unionfs)은 여러 파일 시스템을 스택하고 차이점 만 저장하고 공간을 절약하고 속도를 높입니다. 3. 데몬은 거울과 컨테이너를 관리하고 클라이언트는 상호 작용을 위해 사용합니다. 4. 네임 스페이스 및 CGroup은 컨테이너 격리 및 자원 제한을 구현합니다. 5. 다중 네트워크 모드는 컨테이너 상호 연결을 지원합니다. 이러한 핵심 개념을 이해 함으로써만 Docker를 더 잘 활용할 수 있습니다.

Docker Desktop을 사용하는 방법 Docker Desktop을 사용하는 방법 Apr 15, 2025 am 11:45 AM

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

Centos에서 Gitlab의 백업 방법은 무엇입니까? Centos에서 Gitlab의 백업 방법은 무엇입니까? Apr 14, 2025 pm 05:33 PM

CentOS 시스템 하에서 Gitlab의 백업 및 복구 정책 데이터 보안 및 복구 가능성을 보장하기 위해 CentOS의 Gitlab은 다양한 백업 방법을 제공합니다. 이 기사는 완전한 GITLAB 백업 및 복구 전략을 설정하는 데 도움이되는 몇 가지 일반적인 백업 방법, 구성 매개 변수 및 복구 프로세스를 자세히 소개합니다. 1. 수동 백업 gitlab-rakegitlab : 백업 : 명령을 작성하여 수동 백업을 실행하십시오. 이 명령은 gitlab 저장소, 데이터베이스, 사용자, 사용자 그룹, 키 및 권한과 같은 주요 정보를 백업합니다. 기본 백업 파일은/var/opt/gitlab/backups 디렉토리에 저장됩니다. /etc /gitlab을 수정할 수 있습니다

Docker LNMP에 전화하는 방법 Docker LNMP에 전화하는 방법 Apr 15, 2025 am 11:15 AM

Docker LNMP 컨테이너 호출 단계 : 컨테이너 실행 : Docker Run -D-- 이름 LNMP -Container -P 80:80 -P 443 : 443 LNMP -Stack 컨테이너 IP를 얻으려면 Docker LNMP -Container | grep iPaddress 액세스 웹 사이트 : http : // & lt; 컨테이너 ip & gt;/index.phpssh 액세스 : docker exec -it lnmp -container bash access mysql : mysql -u roo

센토에 하드 디스크를 장착하는 방법 센토에 하드 디스크를 장착하는 방법 Apr 14, 2025 pm 08:15 PM

Centos Hard Disk Mount는 다음 단계로 나뉩니다. 하드 디스크 장치 이름 (/dev/sdx)을 결정하십시오. 마운트 포인트를 만듭니다 ( /mnt /newdisk를 사용하는 것이 좋습니다); 마운트 명령을 실행합니다 (mount /dev /sdx1 /mnt /newdisk); 영구 마운트 구성을 추가하려면 /etc /fstab 파일을 편집하십시오. Umount 명령을 사용하여 장치를 제거하여 프로세스가 장치를 사용하지 않도록하십시오.

See all articles