>  기사  >  운영 및 유지보수  >  Docker를 사용하여 데이터베이스 미러링을 수행하는 방법

Docker를 사용하여 데이터베이스 미러링을 수행하는 방법

PHPz
PHPz원래의
2023-04-26 10:27:391377검색

Docker는 현재 가장 널리 사용되는 컨테이너화 기술로, 애플리케이션과 해당 종속성을 독립적인 컨테이너로 패키징하고 다양한 환경에서 실행할 수 있습니다. 데이터베이스는 애플리케이션의 핵심 구성 요소이며 Docker에서 데이터베이스를 실행하는 것은 데이터베이스 애플리케이션을 테스트, 배포 및 확장하는 편리하고 안전하며 반복 가능한 방법을 제공하므로 매우 일반적인 시나리오입니다.

그렇다면 Docker에서 데이터베이스 이미지를 어떻게 생성하나요? MySQL 데이터베이스 미러를 생성하는 단계는 아래에 자세히 설명되어 있습니다.

1. 공식 MySQL 이미지 다운로드

Docker Hub에서 공식 MySQL 이미지를 다운로드할 수 있습니다.

docker pull mysql/mysql-server

2. 사용자 정의 MySQL 이미지를 생성하세요

. 공식 MySQL 이미지를 직접 사용할 수 있지만 구성 파일, 초기화 스크립트, 데이터 백업 등과 같은 요구 사항을 충족하지 못할 수 있습니다. 그러므로 우리는 공식 이미지를 기반으로 우리의 요구에 맞는 맞춤형 이미지를 만들어야 합니다.

1. Dockerfile 만들기

Dockerfile은 Docker 이미지를 빌드하기 위한 일련의 지침이 포함된 텍스트 파일입니다. MySQL 공식 이미지를 기본으로 사용하고, 이후 구성 파일, 초기화 스크립트, 데이터 백업 등을 추가하여 맞춤형 이미지를 생성합니다.

이 예시에서는 다음 내용으로 Dockerfile 파일을 생성합니다.

FROM mysql/mysql-server

# 安装telnet和net-tools
RUN yum update && yum install -y telnet net-tools

# 添加自定义配置文件
ADD my.cnf /etc/mysql/my.cnf

# 添加初始化脚本
ADD init.sql /docker-entrypoint-initdb.d/

# 添加数据备份
ADD backup.sql /tmp/backup.sql

위 Dockerfile 파일에 대한 설명은 다음과 같습니다.

  • FROM mysql/mysql-server: MySQL 공식 이미지를 기본 이미지로 사용합니다.
  • RUN yum update && yum install -y telnet net-tools: telnet 및 net-tools 도구를 설치합니다.
  • ADD my.cnf /etc/mysql/my.cnf: 사용자 정의 구성 파일 my.cnf를 /etc/mysql/ 디렉터리에 추가합니다.
  • ADD init.sql /docker-entrypoint-initdb.d/: 초기화 스크립트 init.sql을 /docker-entrypoint-initdb.d/ 디렉터리에 추가합니다.
  • ADD backup.sql /tmp/backup.sql: /tmp/ 디렉터리에 데이터 백업 backup.sql을 추가합니다.

2. 이미지 빌드

이 예에서는 Dockerfile 파일, 사용자 정의 구성 파일, 초기화 스크립트, 데이터 백업 및 기타 리소스를 준비했습니다. 다음으로 Dockerfile 파일이 있는 디렉터리에서 다음 명령을 실행하여 이미지를 빌드해야 합니다.

docker build -t my-mysql:latest .

그 중 -t는 이미지 이름을 지정하는 데 사용되며 :latest는 최신 버전을 사용한다는 의미입니다.

3. MySQL 컨테이너 실행

이제 사용자 정의 MySQL 이미지를 성공적으로 생성했으므로 컨테이너에서 이미지를 실행하고 컨테이너에 이름을 할당합니다.

docker run -d -p 3306:3306 --name my-mysql -v /data/mysql:/var/lib/mysql my-mysql

그 중에서 -d는 컨테이너를 실행한다는 의미입니다. 배경, -p는 컨테이너의 3306 포트를 호스트의 3306 포트에 매핑하고, -v는 호스트의 /data/mysql 디렉터리를 컨테이너의 /var/lib/mysql 디렉터리에 매핑하며, my-mysql은 컨테이너의 이름을 나타냅니다.

이제 MySQL 클라이언트 도구를 사용하여 MySQL 컨테이너에 연결하고 제대로 실행되는지 테스트할 수 있습니다.

mysql -h 127.0.0.1 -P 3306 -u root -p

4. 결론

이 과정을 통해 Docker에서 사용자 정의 MySQL 이미지를 생성하고 이미지를 실행하는 방법을 배웠습니다. 이를 통해 데이터베이스 애플리케이션을 더 쉽게 테스트, 배포 및 확장할 수 있습니다. 실제 프로젝트에서는 필요에 따라 더 많은 사용자 정의 구성 및 초기화 스크립트는 물론 백업 및 복구 데이터와 기타 기능을 추가할 수 있습니다.

위 내용은 Docker를 사용하여 데이터베이스 미러링을 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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