> 백엔드 개발 > PHP 튜토리얼 > PHP를 사용하여 데이터베이스 컨테이너화된 백업을 구현하는 방법

PHP를 사용하여 데이터베이스 컨테이너화된 백업을 구현하는 방법

王林
풀어 주다: 2023-05-16 06:00:01
원래의
827명이 탐색했습니다.

오늘날의 클라우드 시대를 맞이하여 소프트웨어 개발, 배포, 운영 및 유지 관리 분야에서 컨테이너화 기술이 점점 더 주목받고 있습니다. 컨테이너화 기술을 사용하면 애플리케이션을 더 잘 관리하는 데 도움이 될 뿐만 아니라 데이터베이스 백업과 같은 운영 및 유지 관리 작업도 단순화됩니다. 이 문서에서는 PHP에서 데이터베이스 컨테이너형 백업을 구현하는 방법에 대해 설명합니다.

1. 데이터베이스 컨테이너화된 백업이란 무엇입니까?

기존 데이터베이스 백업은 운영 체제와 하드웨어에 의존하는 반면, 컨테이너화된 백업은 데이터와 컨테이너를 함께 패키지하고 컨테이너를 기반으로 전체 애플리케이션과 데이터를 백업합니다. 이렇게 하면 하드웨어 및 운영 체제 제한을 피할 수 있으며 프로그램의 지속적인 작동을 촉진할 수도 있습니다.

2. PHP는 데이터베이스 컨테이너형 백업을 어떻게 구현합니까?

PHP에서 데이터베이스 컨테이너형 백업을 구현하는 방법은 여러 가지가 있습니다. 여기서는 주로 Docker 기반 백업 솔루션을 소개합니다.

  1. Docker 설치 및 사용

먼저 공식 웹사이트에서 다운로드할 수 있는 Docker를 설치해야 합니다. 웹사이트 Docker CE(Community Edition)의 해당 버전을 설치합니다. 설치가 성공적으로 완료되면 터미널에 docker version 명령을 입력하여 Docker의 버전 정보와 상태를 확인할 수 있습니다.

다음으로 Docker 명령을 사용하여 로컬 이미지 웨어하우스를 초기화하고 백업해야 하는 데이터베이스를 컨테이너에 매핑해야 합니다.

  1. Create MySQL 컨테이너

먼저 백업용 MySQL 컨테이너를 생성해야 합니다.

다음 명령을 실행하세요:

docker run --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d -p 3306:3306 mysql:5.7
로그인 후 복사

위 명령은 자동으로 MySQL5.7 버전 이미지를 다운로드하고 컨테이너에서 MySQL 서비스를 시작합니다. 그 중 --name 매개변수는 컨테이너 이름을 지정하는 데 사용되며, -e 매개변수는 MySQL의 루트 비밀번호를 설정하는 데 사용되며, -d 매개변수는 데몬 모드에서 컨테이너를 시작하는 것을 나타내며, -p 매개변수는 MySQL의 3306 매핑을 나타냅니다. 포트를 호스트의 3306 포트로 연결하면 나중에 연결을 위해 MySQL 클라이언트를 쉽게 사용할 수 있습니다.

  1. 백업 컨테이너 만들기

MySQL 컨테이너에 백업 컨테이너 만들기:

docker run --rm --link mysql:mysql -v /home/mysql_backup:/backup mayswind/mysql-backup
로그인 후 복사

위 명령을 실행하면 로컬 /home/mysql_backup 디렉터리에 백업 파일이 생성됩니다.

그 중 --rm 매개변수는 컨테이너 종료 후 자동으로 삭제됨을 나타내고 --link 매개변수는 이전에 생성된 MySQL 컨테이너를 연결하는 데 사용되며 -v 매개변수는 백업 파일이 다음 위치에 저장됨을 나타냅니다. 호스트의 /home/mysql_backup 디렉토리.

mayswind/mysql-backup은 Docker Hub에서 다운로드할 수 있는 백업 컨테이너의 이미지라는 점에 주목할 필요가 있습니다. 이 컨테이너는 MySQL 컨테이너의 자동 백업 기능을 제공하므로 더욱 편리하고 실용적입니다.

  1. 예약 백업

컨테이너화된 백업에서는 예약 백업도 매우 중요한 연결고리입니다. crontab 명령을 통해 예약된 백업을 설정할 수 있습니다. 예:

0 3 * * * /bin/bash /home/mysql_backup/mysql_backup.sh
로그인 후 복사

위 명령은 /home/mysql_backup/mysql_backup.sh 스크립트가 매일 아침 3시에 한 번 실행되어 자동으로 백업된다는 의미입니다. MySQL 데이터.

그 중 mysql_backup.sh 스크립트의 내용은 다음과 같습니다.

#!/bin/bash
OUTFILE="/backup/mysql_backup_$(date +%Y-%m-%d_%H-%M-%S).sql"
docker run --rm --link mysql:mysql -v /home/mysql_backup:/backup mayswind/mysql-backup backup --output-file=$OUTFILE --single-transaction
로그인 후 복사
  1. 백업 복원

백업을 복원해야 하는 경우 다음 단계를 따르세요.

a. 예:

docker cp 2019-11-25_11-15-34.sql mysql:/backup/
로그인 후 복사

b MySQL 컨테이너에서 다음 명령을 실행합니다.

mysql -uroot -p123456 < /backup/2019-11-25_11-15-34.sql
로그인 후 복사

이 명령은 백업 파일을 MySQL로 복원합니다.

3. 요약

컨테이너화된 백업을 통해 애플리케이션과 데이터를 함께 패키지하여 보다 편리한 백업 및 복구 작업을 수행할 수 있습니다. PHP에서는 Docker 도구를 사용하여 컨테이너화된 백업을 구현할 수 있습니다. 구체적인 방법은 비교적 간단하고 구현하기 쉽습니다. 나는 이 기사가 데이터베이스 컨테이너화된 백업을 구현하기 위해 PHP를 찾고 있는 독자들에게 확실한 참고 가치가 될 수 있다고 믿습니다.

위 내용은 PHP를 사용하여 데이터베이스 컨테이너화된 백업을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿