php로 만든 디비 백업스크립트(쉘용)
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개
Photofly
19년 전
좋은 팁 감사합니다.... 적용해 봐야겠네요....^^
19년 전
좋은 정보 감사합니다 ^^
19년 전
적당히 수정하면 개별 디비용도 만들수 있으리라고 봅니다.
빨간망토의비밀
19년 전
좋은 정보 감사.
19년 전
오우 멋진팁입니다 잘 사용하겠습니다.
19년 전
좋은팁 감사드립니다.
초보를 위해서 실행방법좀 올려주시면 고맙겠습니다.
초보를 위해서 실행방법좀 올려주시면 고맙겠습니다.
18년 전
감사합니다..
게시글 목록
| 번호 | 제목 |
|---|---|
| 24900 |
계약서
업무제휴계약서_인터넷
|
| 24899 | |
| 24898 | |
| 24897 | |
| 24896 |
견적서
수의계약 견적서_공사관리
|
| 24895 | |
| 24894 | |
| 24893 | |
| 24892 | |
| 24891 | |
| 24890 | |
| 24889 | |
| 24888 | |
| 24887 | |
| 24886 | |
| 11687 |
JavaScript
일러스트 미리보기 툴을 찾으시는 분들께..
4
|
| 24885 |
계약서
부동산 매매계약서
|
| 24884 | |
| 24883 | |
| 24882 |
계약서
물품매매계약서_계약
|
| 24881 |
계약서
물품구매 표준계약서_구매
|
| 24879 | |
| 24878 | |
| 24877 |
견적서
무역 영문견적서_회사
|
| 24875 |
기획서
마케팅 기획서_기업일반
1
|
| 24874 |
계약서
동업계약서샘플_일반계약
|
| 24873 |
계약서
대리점 계약서_일반계약
|
| 24872 | |
| 24871 | |
| 11683 | |
| 11662 |
Flash
그누보드용 플래시 최근게시물
20
|
| 11659 |
기타
인물 사진 보정하기
2
|
| 29136 | |
| 11647 |
JavaScript
왼쪽에 달면 좋을만한 소스
11
|
| 11644 | |
| 11641 |
JavaScript
최적의 해상도 설정법
2
|
| 11634 | |
| 11632 | |
| 29135 | |
| 11631 |
JavaScript
1px 라인 css와 2개이상 class 적용.
|
| 11628 | |
| 24870 | |
| 24869 |
계약서
기술제휴계약서_영업
|
| 24868 | |
| 24867 | |
| 24866 | |
| 24865 |
계약서
근로계약서_기업일반
|
| 24864 |
계약서
공증 채무승인계약서_채권
|
| 24863 | |
| 24862 |
계약서
고용계약서_총무
|
| 24861 | |
| 24860 |
계약서
계약서_부동산
|
| 11627 | |
| 24859 | |
| 24858 | |
| 24856 |
견적서
견적서_일반기업
1
|
| 24855 | |
| 24854 | |
| 24853 | |
| 24852 | |
| 29130 |
HTML
퀵마스크의 활용 예제
4
|
| 11625 |
JavaScript
익스플로러7 팝업창의 주소창 없애기
1
|
| 11622 | |
| 11617 | |
| 11604 | |
| 11596 | |
| 11591 | |
| 11586 | |
| 29128 |
HTML
외부필터 설치하기
1
|
| 11583 | |
| 11579 | |
| 11578 | |
| 11574 |
MySQL
MySQL 한글 매뉴얼
3
|
| 11566 |
Flash
swf파일에 링크 걸려면??
7
|
| 11565 | |
| 11562 | |
| 11561 |
MySQL
PHP 5.2.0 설치시 MySQL 문제
|
| 29125 |
HTML
움직이는 사진에 효과 넣을때
2
|
| 11558 |
기타
필름효과내기
2
|
| 11556 |
JavaScript
한글폰트가 안 보일때...
1
|
| 11533 |
Flash
국내지도 소스입니다.
22
|
| 11529 |
JavaScript
회전목마 - 스크롤링 소스
3
|
| 29118 |
HTML
포토샵 효과 모음2
6
|
| 11526 |
기타
포토샵 효과 모음
2
|
| 11519 |
JavaScript
[팁] 물방울 효과2
6
|
| 29115 |
HTML
[팁] 물방울 효과
2
|
| 11518 |
MySQL
official 64bit mysql
|
| 11516 | |
| 11515 | |
| 11509 |
JavaScript
CS2에서 포토샵 PSD파일과 일러스트 AI파일 미리보기 기능
5
|
| 11508 | |
| 29112 |
HTML
HTML 사전입니다.
2
|
| 11496 | |
| 29109 | |
| 29106 | |
| 11495 | |
| 11488 |
JavaScript
Ajax가 뭐죠?
6
|
| 11486 | |
| 11483 | |
| 11471 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기