crontab 에 등록해놓고 예외시킨 디비를 제외한 모든 디비를
백업받는 스크립트 입니다.
이하 소스 입니다.
#!/usr/local/php/bin/php -q
<?php
@set_time_limit (0);
@ini_set ("memory_limit", "20M");
$save_dir = '절대경로/dbbackup';//저장할 장소, 절대경로/dbbackup 퍼미션은 777로 주세요
$dateYmdH = date("YmdH");
$break_dbname = '예외디비명1|예외디비명2';//디비백업에 열외시킬 디비들
$deldate = 7;//삭제일 현재는 7일지난 데이터는 삭제
echo "[백업한 sql] \n\n";
mysql_connect('디비접속호스트', 'root', '디비루트패스워드');
$db_list = mysql_list_dbs();
$i = 0;
$cnt = mysql_num_rows($db_list);
while ($i < $cnt) {
$dbname = mysql_db_name($db_list, $i);
$i++;
if (!empty($dbname)) {
if (!empty($break_dbname) && preg_match("`^(" . $break_dbname . ")$`i", $dbname))
continue;
echo "[ " . $dbname . "]\n";
exec('/usr/local/mysql/bin/mysqldump -h디비접속호스트 -uroot -p루트패스워드 ' . $dbname . ' > ' . $save_dir . '/' . $dbname . $dateYmdH . '.sql');
}
}
echo "\n\n[삭제한 sql] \n\n";
$d = dir($save_dir);
while (false !== ($entry = $d->read())) {
if (!preg_match("|^\.|", $entry)) {
if (!empty($break_dbname) && preg_match("`^(" . $break_dbname . ")[0-9]{0,10}\.sql$`i", $entry))
continue;
$temp_file = $save_dir . '/' . $entry;
$temp_mtime = @filemtime($temp_file);
$temp_during = time() - $temp_mtime;
if ($temp_during > (60 * 60 * 24 * $deldate)){
$temp_cnt++;
@unlink($temp_file);
echo "[" . $temp_file . "]\n";
}
}
}
$d->close();
exit;
?>
소스중에 #!/usr/local/php/bin/php -q 이부분은 자신의 php환경에 맞추어야 합니다.
이스크립트는 mysql 루트 권한이 있어야 사용가능합니다.
위 소스를 파일로 서버에 저장한 후 퍼미션을 755 로 주시기 바랍니다.
크론탭에 등록하는 방법
# crontab -e
30 */6 * * * /home/conf/cronwork/dbbackup.php #6시간에 한번씩
라고 넣고 저장
6시간에 한번씩, 해당 시간의 30분에 실행됩니다.
위의 세팅 그대로 사용하면
하루에 4번, 7일동안 보관하므로
하나의 디비에 대해 총 28개의 백업sql이 존재하게 됩니다.<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
백업받는 스크립트 입니다.
이하 소스 입니다.
#!/usr/local/php/bin/php -q
<?php
@set_time_limit (0);
@ini_set ("memory_limit", "20M");
$save_dir = '절대경로/dbbackup';//저장할 장소, 절대경로/dbbackup 퍼미션은 777로 주세요
$dateYmdH = date("YmdH");
$break_dbname = '예외디비명1|예외디비명2';//디비백업에 열외시킬 디비들
$deldate = 7;//삭제일 현재는 7일지난 데이터는 삭제
echo "[백업한 sql] \n\n";
mysql_connect('디비접속호스트', 'root', '디비루트패스워드');
$db_list = mysql_list_dbs();
$i = 0;
$cnt = mysql_num_rows($db_list);
while ($i < $cnt) {
$dbname = mysql_db_name($db_list, $i);
$i++;
if (!empty($dbname)) {
if (!empty($break_dbname) && preg_match("`^(" . $break_dbname . ")$`i", $dbname))
continue;
echo "[ " . $dbname . "]\n";
exec('/usr/local/mysql/bin/mysqldump -h디비접속호스트 -uroot -p루트패스워드 ' . $dbname . ' > ' . $save_dir . '/' . $dbname . $dateYmdH . '.sql');
}
}
echo "\n\n[삭제한 sql] \n\n";
$d = dir($save_dir);
while (false !== ($entry = $d->read())) {
if (!preg_match("|^\.|", $entry)) {
if (!empty($break_dbname) && preg_match("`^(" . $break_dbname . ")[0-9]{0,10}\.sql$`i", $entry))
continue;
$temp_file = $save_dir . '/' . $entry;
$temp_mtime = @filemtime($temp_file);
$temp_during = time() - $temp_mtime;
if ($temp_during > (60 * 60 * 24 * $deldate)){
$temp_cnt++;
@unlink($temp_file);
echo "[" . $temp_file . "]\n";
}
}
}
$d->close();
exit;
?>
소스중에 #!/usr/local/php/bin/php -q 이부분은 자신의 php환경에 맞추어야 합니다.
이스크립트는 mysql 루트 권한이 있어야 사용가능합니다.
위 소스를 파일로 서버에 저장한 후 퍼미션을 755 로 주시기 바랍니다.
크론탭에 등록하는 방법
# crontab -e
30 */6 * * * /home/conf/cronwork/dbbackup.php #6시간에 한번씩
라고 넣고 저장
6시간에 한번씩, 해당 시간의 30분에 실행됩니다.
위의 세팅 그대로 사용하면
하루에 4번, 7일동안 보관하므로
하나의 디비에 대해 총 28개의 백업sql이 존재하게 됩니다.<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
댓글 7개
게시글 목록
| 번호 | 제목 |
|---|---|
| 8624 |
기타
소유권변경
|
| 8623 | |
| 8617 | |
| 8615 | |
| 28464 | |
| 8613 | |
| 8612 | |
| 8611 |
JavaScript
vim 의 들여쓰기 + 색상 눈 덜피곤 c++ php 등.. (리눅스용)
|
| 8610 |
JavaScript
vim 의 간단한 사용법
|
| 8609 |
JavaScript
[자바스크립트] 상태표시줄 제어 + 간단한 복사 제어
|
| 8606 |
Linux
/etc 디렉토리 아래의 파일들
2
|
| 8605 |
기타
shadow 잠금 해제
|
| 8604 | |
| 8603 |
JavaScript
yum 업데이트 되는곳 7.3 or 페도라
|
| 8602 |
MySQL
mysql 링크하기
|
| 8601 | |
| 8600 |
MySQL
mysql.sock 삭제 하였을 경우
|
| 8599 | |
| 8598 | |
| 8597 |
JavaScript
ps 시 화면 짤리는부분 보이게 하기
|
| 8596 | |
| 8595 | |
| 8594 |
기타
chmod 의 스틱키
|
| 8593 |
JavaScript
tripwire 의 twr 파일 보기
|
| 8592 |
JavaScript
최근 사용자 접속 리스트 보기
|
| 8591 | |
| 8590 | |
| 8589 |
JavaScript
atd 데몬
|
| 28463 | |
| 8588 |
JavaScript
portmap
|
| 8587 | |
| 8586 | |
| 8585 |
JavaScript
md5sum 사용방법
|
| 8584 |
JavaScript
TAR 압축방법
|
| 8583 | |
| 8581 | |
| 8580 |
기타
crontab 사용하기
|
| 8579 |
JavaScript
umask 설정법
|
| 8578 | |
| 8577 |
기타
Find 명령어 활용
|
| 8576 |
기타
zip 압축 해제
|
| 8575 |
JavaScript
삼바(samba)에서 내부만 들어오게 하기
|
| 8574 | |
| 8572 | |
| 8571 |
JavaScript
quota 젠체 용량 확인
|
| 8570 | |
| 8569 | |
| 8568 |
JavaScript
런레벨 편집
|
| 8567 |
기타
리눅스에서 문자찾기
|
| 8566 | |
| 8565 |
JavaScript
삼바로 리눅스에서 윈도우로 공유하기
|
| 8564 |
JavaScript
shadow 패스워드 잠금 해제 하기
|
| 8563 | |
| 8562 | |
| 8561 |
JavaScript
vim에서 컬러는 나오게 하기
|
| 8560 | |
| 8558 | |
| 8557 |
MySQL
my.cnf 파일은 어디에?
|
| 8556 | |
| 8555 |
MySQL
cron 설정
|
| 8554 |
JavaScript
호스트네임 바꾸기
|
| 8553 |
JavaScript
하드링크와 심볼릭링크?
|
| 28462 |
HTML
콘솔의 화면보호기능을 끄려면?
|
| 8552 |
기타
스틱키
|
| 8551 |
JavaScript
날짜 바꾸기 date 명령을 이용
|
| 28461 |
HTML
스왑 사용 안하기
|
| 8549 | |
| 8548 |
기타
SSH
|
| 8547 |
JavaScript
rsync 백업
|
| 8545 |
JavaScript
저 사양 PC로 리눅스 라우터 만들기
1
|
| 8544 |
Linux
Tripwire
|
| 8543 | |
| 8542 | |
| 8541 | |
| 8540 |
JavaScript
링크 시킨 파일 찾기
|
| 8539 |
JavaScript
리눅스 하드웨어 정보 보기
|
| 8538 | |
| 8537 | |
| 8536 |
MySQL
my.cnf 파일은 위치..
|
| 8535 |
MySQL
부팅시 자동으로 mysql 서버 자동실행
|
| 8533 |
MySQL
MySQL 루트비번 분실시 대처요령
1
|
| 8532 |
MySQL
mysql에서 log 파일 남기기
|
| 8531 |
MySQL
ALTER 테이블 추가,변경
|
| 8530 |
MySQL
sql 파일로 테이블 간단히 만들기
|
| 8529 |
MySQL
mysql 4.1 의 password()
|
| 8528 |
MySQL
mysql 에서 최대 사용자 수
|
| 8525 | |
| 8524 | |
| 8523 |
기타
핑(ping) 막기
|
| 8522 | |
| 8521 |
JavaScript
su 사용자 제한하기
|
| 8520 | |
| 8519 |
JavaScript
기본적인 삼바 설정
|
| 8518 |
기타
실시간 로그 보기..
|
| 8517 | |
| 8516 |
JavaScript
부팅 로고 삭제
|
| 8515 |
JavaScript
콘솔에서 해상도 높이기
|
| 8514 | |
| 8513 | |
| 8512 |
JavaScript
ssh로 접속할때 메시지를 보여주는 방법..
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기