레이블이 백업인 게시물을 표시합니다. 모든 게시물 표시
레이블이 백업인 게시물을 표시합니다. 모든 게시물 표시

2012-09-17

DBMS/MySQL] Mysql Dump 백업하기 스크립트


안녕하세요. mindline 입니다.

별건 아닌데... 제가 필요에 따라 만들어 쓰는 스크립트입니다.
혹시 도움이 될까 해서 올려 봅니다.

------------ 시작 -----------------

#!/bin/sh

backup_dir="/home/mysqlbackup"
dat=`date +%Y%m%d`

if [ ! -d "$backup_dir/$dat" ];
then
  mkdir $backup_dir/$dat
fi

cd /var/lib/mysql

for dbdir in *
do
  if [ -d $dbdir ];
  then
    mkdir $backup_dir/$dat/$dbdir
    cd $dbdir

    for table in *MYI
    do
      tname=`basename $table .MYI`
      mysqldump -p비밀번호 -uroot $dbdir $tname > $backup_dir/$dat/$dbdir/$tname.dump
    done

    cd ..
    sleep 1
  fi
done



#pastdat=`date --date '7 days ago' +%Y%m%d`
#rm -rf $backup_dir/$pastdat

---------------- 끝 ------------------------

대략 요령껏 디렉토리 경로등은 변경하세여. ^^;

매일 크론에 등록해 놓구 쓰면 되겠져...

제일 밑에 두줄은 계속 쌓이기만 하면 하드가 Full 될테니...
7일일 전의 디렉토리는 지우라는 명령어 입니다.

( rm -rf 조심하세여. 현재 주석 처리 입니다. ^^ )


대략 이렇게 됩니다.
20031127/dbname1/tablename1.dump
20031127/dbname1/tablename2.dump
20031127/dbname2/tablename1.dump
20031127/dbname2/tablename2.dump

:-)


그럼.

2012-09-12

FreeBSD] 시스템 백업에 관한 얘기.



우선 쉘 스크립트를 작성하실 수 있어야 합니다.
(몰라도 가능하지만 모르면 그만큼 원하는 형태로 백업 받기 어려움)
또한 tar, rsync, cp, date, mysqldump (mysql DB라면), export(오라클이라면), mt, dump(테잎 백업) 등의 명령과 정기적으로 명령을 자동으로 실해시켜주는 cron 에 대해서도 아셔야 합니다.

두 가지 예만 들어들일테니 참고하시고 응용해보세요.
(테스트는 해보지 않고 쓰니 직접 확인해보세요.)


1. /etc 등 주요 설정과 관련된 디렉토리를 백업한다고 할 때


코드:

#!/bin/bash
#
# 파일명 : /root/bin/backup.sh
#
# /etc 전체를 백업디렉토리에 etc-년월일-시간.tar.gz 이름으로 백업한다.


DATE=`date +%Y%m%d-%H`
BACKUP_DIR="/backup/system"


# etc 백업

tar cvf $BACKUP_DIR/etc-$DATE.tar /etc
gzip $BACKUP_DIR/etc-$DATE.tar





중요한 것은 /backup 이나 /backup/system 디렉토리는 모두 퍼미션이 700으로 하셔야 합니다.

그래야 다른 일반 사용자들이 백업해둔 파일에 접근할 수 없는 것이죠.


코드:

# chmod 700 /backup
# chmod 700 /backup/system

# chmod 700 backup.sh
# ./backup.sh (이렇게 했을 때 /backup/system/ 에 백업됐는지 확인하시면 됩니다.)




2. 아래는 rsync를 이용해서 퍼미션과 소유자를 그대로 유지한 상태로 디렉토리를 통채로 복사하는 예입니다.



코드:


#!/bin/bash
#
# 파일명 : /root/bin/backup_dir.sh
#
# /home, /abcd 전체를 /backup/ 아래로 복사한다.


BACKUP_DIR="/backup"
DIR_LIST="/home /abcd"


for i in $DIR_LIST
do
   /usr/bin/rsync -avxH $i $BACKUP_DIR$i
done





코드:

# chmod 700 backup_dir.sh




rsync는 디렉토리안에 파일이 많으면 목록 인식하는데 시간이 걸린다는 것 참고하세요.

뭐 저런식으로 됐다면 crontab 에 넣어주면 백업을 해주겠죠.

아래는 매주 일요일 새벽 2:31과 2:51분에 backup.sh, backup_dir.sh이 실행되도록 하는 예입니다.



# crontab -e



코드:


31 2 * * 0 /root/bin/backup.sh > /dev/null 2>&1
51 2 * * 0 /root/bin/backup_dir.sh > /dev/null 2>&1





지금까지 하나의 예입니다.
모든 것을 다 알려주면 역시 님에게는 전혀 도움이 안되며, 서버 관리를 하시면 스스로 방법을 찾아내고, 문제를 해결하실 수 있어야 합니다.
이번 기회에 쉘 스크립트에 대해 배워보세요.



* 참고글
- [기초] 작업 자동화, cron 설정 http://coffeenix.net/board_view.php?cata_code=0&bd_code=97 (좋은진호)
- Bash를 이용한 쉘 스크립팅 완전 가이드 http://coffeenix.net/go.php?site_code=181&go=/doc/HOWTOs/html/Adv-Bash-Scr-HOWTO/ (번역:차현진)
- 시스템 백업 카테고리 http://coffeenix.net/?cata_code=54