>데이터 베이스 >MySQL 튜토리얼 >MongoDB 데이터베이스를 백업, 복원 및 마이그레이션하는 방법

MongoDB 데이터베이스를 백업, 복원 및 마이그레이션하는 방법

不言
不言원래의
2019-03-23 15:16:183472검색

mongodump는 데이터베이스 백업 생성을 위해 mongodb에서 제공하는 유틸리티입니다. 이는 라이브 서버 데이터베이스를 매우 효율적으로 백업하는 데 고려할 수 있는 매우 유용한 유틸리티입니다. 데이터베이스 복원을 위해서는 mongorestore 명령을 사용해야 합니다.

MongoDB 데이터베이스를 백업, 복원 및 마이그레이션하는 방법

1. mongodb 데이터베이스 백업(mongodump)

MongoDB 데이터베이스를 백업하는 방법에는 여러 가지가 있습니다. 모든 데이터베이스, 단일 컬렉션 또는 단일 데이터베이스를 백업하려면 mongodump 명령을 사용하십시오.

단일 데이터베이스 백업

단일 데이터베이스(mydb라는 이름)만 백업하려면 이 명령을 사용하세요. 백업은 /backup/db/ 디렉터리에 생성됩니다.

$ mongodump --db mydb --out / backup / db /

-db - 백업할 데이터베이스의 이름
-out - 데이터베이스 백업 위치. 그러면 데이터베이스 이름으로 폴더가 생성됩니다.

원격 데이터베이스 연결 백업에는 아래와 같이 호스트, 포트, 사용자 이름, 비밀번호를 지정할 수 있습니다.

$ mongodump --host 10.0.1.7 --port 27017 --username admin --password somepassword --db mydb --out / backup / db /

모든 데이터베이스 백업

모든 데이터베이스를 백업하려면 다음 명령을 실행하세요. 여기서 /data/db/는 mongodb 데이터 디렉터리의 위치이고 /backup/db는 백업 디렉터리의 위치입니다.

$ mongodump --out / backup / db /

원격 데이터베이스의 호스트와 포트를 지정할 수 있습니다.

단일 컬렉션 백업

이 명령은 데이터베이스에서 단일 컬렉션을 백업합니다. 백업 파일은 dump/mydb/ 디렉터리에 생성됩니다.

$ mongodump --collection mycollection --db mydb --out / backup / db /

2. mongorestore를 사용하여 MongoDB 데이터베이스 복원

mongorestore는 mongodb 데이터베이스 백업을 복원하는 데 사용되는 명령줄 도구입니다. 여기서 /data/db/는 mongodb 데이터 디렉터리의 위치이고 /backup/db는 백업 디렉터리의 위치입니다.

$ mongorestore --db mydb --drop / backup / db / mydb

-drop - 데이터베이스가 이미 존재하는 경우 데이터베이스를 삭제합니다.

백업 파일을 원격 서버로 이동하고 그곳에서 동일한 명령을 실행하면 백업을 복원할 수 있습니다.

3. MongoDB 백업 쉘 스크립트

다음 스크립트는 데이터베이스를 정기적으로 백업하도록 스케줄러에서 쉽게 예약할 수 있습니다. 다음 파일을 생성하세요.

$ vi /backup/mongo-backup.sh

파일에 다음 내용을 추가하세요. 그에 따라 데이터베이스 호스트 이름, 데이터베이스 이름, 사용자 이름 및 비밀번호를 업데이트하십시오.

#!/bin/sh
 
TODAY=`date +%d%b%Y`
BACKUP_DIR=/backup/db
 
mkdir -p ${BACKUP_DIR}/${TODAY}
 
mongodump -h <DATABASE_HOST> -d <DATABASE_NAME> -u <USERNAME> -p <PASSWRD> --out ${BACKUP_DIR}/${TODAY}/

이제 매일 실행되도록 crontab에서 구성하세요.

0 2 * * * /backup/mongo-backup.sh

이 글은 여기서 끝났습니다. 더 흥미로운 내용을 보려면 PHP 중국어 웹사이트의 MySQL 비디오 튜토리얼 칼럼을 주목하세요!

위 내용은 MongoDB 데이터베이스를 백업, 복원 및 마이그레이션하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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