Mysql 백업을 드랍박스에 하기
컨텐츠 정보
- 17,124 조회
- 4 댓글
- 0 추천
-
목록
본문
지난 번에 오드로이드 백업 및 드랍박스 업로드 자동 스크립트 만들기를 올렸었는데요,
웹서버에서 중요한 데이터베이스 백업은 못하고 있었습니다.
웹서버 안에 있는 파일도 중요하지만, 데이터베이스가 날아가면 그 파일들이 쓸모가 없어지기 때문에
데이터베이스의 백업도 정말 중요한 작업입니다.
그래서 구글 검색해보니 우리나라에서 검색 결과는 잘 안보여, 작성하게 되었습니다.
레퍼런스는 관련링크1에 있으니 참고바랍니다.
백업 스크립트의 특징은 sh파일이 아닌 php 로 작성하는 것입니다. (스크립트로 하시려면 새로 작성한 두번째 방법을 참조하세요. 링크)
sh파일을 수정해서 DB를 백업하면 좋지만... 제가 그정도 수준은 아니라(ㅠㅠ) php버전으로 소개해드립니다.
그래도 지난 강좌에 쓰였던 드랍박스API 설치가 필요없어 DB만 백업하려면 이렇게 분리하는 것도 좋아보입니다.
거두절미하고 바로 PHP파일을 작성합니다.
울트라에디터나 editplus 같은 편집기로 작성해야 에러가 적습니다.
/**
* Quickly and easily backup your MySQL database and have the .tgz copied to
* your Dropbox account.
*
* Copyright (c) 2012 Eric Silva
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*
* @author Eric Silva [eric@ericsilva.org] [http://ericsilva.org/]
* @version 1.0.0
*/
require('DropboxUploader.php');
// location of your temp directory
$tmpDir = "/임시저장소/";
// username for MySQL
$user = "MYSQL아이디";
// password for MySQL
$password = "MYSQL비밀번호";
// database name to backup
$dbName = "백업하고싶은DB이름";
// hostname or IP where database resides
$dbHost = "localhost";
// the zip file emailed to you will have this prefixed
$prefix = "db_";
// username for Dropbox
$dropbox_user = "드랍박스아이디";
// password for Dropbox
$dropbox_password = "드랍박스비밀번호";
// Destination folder in Dropbox (folder will be created if doesn't yet exist)
$dropbox_dest = "db_backups";
// Create the database backup file
$sqlFile = $tmpDir.$prefix.date('Y_m_d').".sql";
$backupFilename = $prefix.date('Y_m_d').".tgz";
$backupFile = $tmpDir.$backupFilename;
$createBackup = "mysqldump -h ".$dbHost." -u ".$user." --password='".$password."' ".$dbName." > ".$sqlFile;
//echo $createBackup;
$createZip = "tar cvzf $backupFile $sqlFile";
//echo $createZip;
exec($createBackup);
exec($createZip);
try {
// Upload database backup to Dropbox
$uploader = new DropboxUploader($dropbox_user, $dropbox_password);
$uploader->upload($backupFile, $dropbox_dest, $backupFilename);
} catch(Exception $e) {
die($e->getMessage());
}
// Delete the temporary files
unlink($sqlFile);
unlink($backupFile);
?>
위에 한글로 적은 부분은 반드시 자신의 웹서버에 맞게 수정해야 합니다.
수정 후 원하는 이름으로 저장하면 됩니다. (ex - dbbackup.php - 첨부파일에 첨부)
그리고 DropboxUploader.php파일도 위에서 만든 파일과 같은 경로에 넣어야 합니다.
https://github.com/jakajancar/DropboxUploader
위 링크에 들어가서 오른쪽 제일 밑에 Download ZIP을 클릭하여 받거나, 첨부파일을 받으면 됩니다.
이제 두 파일을 원하는 위치에 넣습니다.
저는 /usr/bin/ 에 넣어줬습니다.
이제 cron을 이용하여 자동으로 백업하게 해야합니다.
sh의 경우 간단하게 되지만 php파일의 경우 usr/bin에 있는 php 모듈을 확인해야 합니다.
위 스샷처럼 php파일이 어떤 이름을 가지는지 확인 후 cron 명령어를 넣어주면 됩니다.
1 4 * * * /usr/bin/php5 -q /usr/bin/dbbackup.php
※ 2013/11/13 스크립트로 업로드하는 방법을 추가했습니다.
-
등록일 2020.09.18
-
등록일 2020.09.08도커 허브에서 매일 이미지 빌드하기댓글 2
-
등록일 2020.09.08
-
등록일 2020.07.19
관련자료
-
서명우성짱의 NAS를 운영하고 있습니다.
저의 즐거움이 여러분의 즐거움이면 좋겠습니다.
-
링크
-
첨부등록일 2013.10.14 02:02등록일 2013.10.14 02:02
테베님의 댓글
# directory to place Mysql backups
MYSQLBACKUPDIR=mysql백업할 폴더경로
# file name YYYY-MM-DDHH:MM:SS.sql
BACKUPNAME=`date +%F%T`
# remove dashes and colons from file name
BACKUPNAME=${BACKUPNAME//[-|:]/}
# number of sets to keep
NUMSETS=3
#MYSQL backup 전체 MYSQL을 뜨는 명령어입니다 개별 디비만 뜨는건 -A --add-drop-table를 DB명으로 바꾸시면 됩니다.
mysqldump -u아이디 -p비밀번호 -A --add-drop-table > $MYSQLBACKUPDIR/$BACKUPNAME.sql\
# delete older files greater than $NUMSET
cd $MYSQLBACKUPDIR
LINS=$((NUMSETS + 1))
if [[ $(ls $MYSQLBACKUPDIR | wc -l) > $NUMSETS ]]
then
stat -c "%Y %n" * | sort -rn | tail -n +"$LINS" | \
cut -d ' ' -f 1 --complement | xargs -d '\n' rm
fi
#드랍박스 업로드 부분은 생략했습니다.