MySQL은 다양한 프로젝트와 기업에서 널리 사용되는 인기 있는 오픈 소스 데이터베이스 관리 시스템입니다. 데이터베이스는 프로젝트의 핵심이고, 그 안의 데이터도 프로젝트에서 없어서는 안 될 부분이므로 데이터베이스 백업과 복구는 매우 중요합니다. 이 기사에서는 다양한 백업 및 복구 솔루션을 통해 MySQL 데이터베이스의 보안을 보장하는 방법을 살펴보겠습니다.
유형 1: mysqldump 명령을 사용하여 데이터베이스 백업
mysqldump는 MySQL 백업에 가장 일반적으로 사용되는 명령입니다. 전체 데이터베이스 또는 개별 테이블을 백업할 수 있습니다. mysqldump 명령의 기본 구문은 다음과 같습니다.
mysqldump -h host -u user -p database_name > backup.sql
파라미터 설명:
: 백업된 데이터를 지정된 파일에 저장합니다.
백업된 파일은 로컬 서버나 원격 서버에 저장할 수 있습니다. 데이터베이스를 복원해야 하는 경우 다음 명령을 사용하면 됩니다.
mysql -u user -p database_name < backup.sql
매개변수 설명:
두 번째: MySQL의 바이너리 로그 백업을 사용하세요
MySQL의 바이너리 로그를 사용하여 MySQL 데이터의 모든 변경 사항을 기록할 수 있습니다. 바이너리 로그 백업을 사용하면 백업 후 데이터뿐만 아니라 데이터베이스 복원 시 모든 변경 사항을 복원할 수 있습니다. 바이너리 로그 백업을 생성하려면 다음 단계를 따르세요.
MySQL 구성 파일에 다음 줄을 추가하세요.
[mysqld] log-bin=/var/lib/mysql/binlog/mysql-bin.log
sudo /etc/init.d/mysql restart
다음 명령을 실행하여 바이너리 로그 백업을 생성할 수 있습니다:
SHOW MASTER STATUS;
이 명령을 실행하면 MySQL은 바이너리 로그의 이름과 위치를 반환합니다.
데이터를 복원하려면 다음 명령을 사용하세요.
mysqlbinlog --start-position=512 mysql-bin.000001 > backup.sql
이 명령은 바이너리 로그에서 모든 변경 사항을 읽고 백업 파일에 씁니다. 그런 다음 mysqldump 명령을 사용하여 백업 데이터를 데이터베이스로 복원할 수 있습니다.
셋째: Percona XtraBackup을 사용하여 데이터베이스 백업 및 복원
Percona XtraBackup은 MySQL 데이터베이스를 백업 및 복원하는 도구로, 백업 시간과 복구 시간을 줄이고 백업 및 복구 위험을 줄일 수 있습니다. Percona가 개발하고 유지 관리하는 무료 오픈 소스 도구입니다. Percona XtraBackup을 사용하여 데이터를 백업하고 복원하는 단계는 다음과 같습니다.
Ubuntu 시스템에서는 다음 명령을 사용하여 Percona XtraBackup을 설치할 수 있습니다.
sudo apt-get install percona-xtrabackup
백업을 생성하려면 다음 명령을 사용하세요.
sudo innobackupex --user=root --password=yourpassword /var/backup/
이렇게 하면 /var/backup/ 디렉터리에 전체 백업 파일이 생성됩니다. 백업 시간은 데이터베이스 크기에 따라 다릅니다.
백업을 복원하기 전에 MySQL 서버를 중지하고 기존 MySQL 데이터베이스를 삭제해야 합니다. 백업이 완료된 후 MySQL 서버를 중지합니다.
sudo /etc/init.d/mysql stop
그런 다음 기존 MySQL 데이터베이스를 삭제합니다.
sudo rm -rf /var/lib/mysql/*
마지막으로 백업 파일에서 데이터베이스를 복원합니다.
sudo innobackupex --user=root --password=yourpassword --copy-back /var/backup/
복구 프로세스는 크기에 따라 다소 시간이 걸립니다. 백업 데이터의 완료되면 MySQL 서버를 다시 시작할 수 있습니다.
sudo /etc/init.d/mysql start
요약:
어떤 백업 방법을 사용하든 올바른 방법과 도구를 사용하여 데이터베이스를 백업하고 복원해야 합니다. 여러 백업 솔루션을 사용해야 할 뿐만 아니라 재해 발생 시 적시에 데이터를 복원할 수 있도록 정기적으로 백업을 테스트해야 합니다. 좋은 백업 및 복구 전략은 데이터베이스 보안을 보장하는 데 중요합니다.
위 내용은 MySql을 위한 다양한 백업 및 복구 솔루션: 여러 백업에서 MySQL 데이터베이스를 복원하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!