메뉴 건너뛰기

조회 수 8204 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
가장 정리가 잘 된 스크립트 예제


우선 root로 로그인한후
vi backup.sh를 입력하여 sh파일을 생성해 봅니다.

그리고 아래의 내용을 본인의 환경에 맞게 적당하게 편집한후 저장합니다.
(이때 경로부분은 pwd 명령을 입력하여 절대경로로 입력해줍니다)

---------------------------------------------------------------------------------------
#!/bin/bash
DATE=`date +%Y%m%d`
-->위에 실행이 안되어서 다음과 같이 수정하니 실행 되었다.
DATE=$(date +%Y%m%d)
DB_BACKUP_DIR=/backup/db
WEB_BACKUP_DIR=/backup/web
WEB_DIR=/www_dir

##### MySQL 특정 데이타베이스 백업 #####
mysqldump -uroot -p***** justin > $DB_BACKUP_DIR/justin_$DATE.sql
mysqldump -uroot -p***** xnova > $DB_BACKUP_DIR/xnova_$DATE.sql
 
root가 아닌 각 계정별로 가능하다. root의 암호를 쓰는것은 바람직 하지 않다.계정별 추천.
/usr/local/mysql/bin/mysqldump -u아이디 -p비번 디비이름 > $DB_BACKUP_DIR/디비이름_$DATE.sql

##### MySQL 전체 데이타베이스 백업 #####
mysqldump -uroot -p***** -A > $DB_BACKUP_DIR/all_$DATE.sql

##### 웹파일 백업 (web 디렉토리의 모든내용을 백업) #####
tar czfp $WEB_BACKUP_DIR/web_$DATE.tar.gz $WEB_DIR/web

##### 오래된 백업 삭제 (일주일 전의 파일들만 삭제) #####
WEEKAGO=`date -d "7 days ago" +%Y%m%d`
rm $DB_BACKUP_DIR/*$WEEKAGO.sql
rm $WEB_BACKUP_DIR/*$WEEKAGO.tar.gz

##### 권한 수정 #####
chmod -R 600 $WEB_BACKUP_DIR
chmod -R 600 $DB_BACKUP_DIR

##### 백업 후 FTP로 전송한다면 아래 사용 #####
#REMOTE='192.168.0.123'    ## FTP 리모트 변수 (서버IP)
#ID='test'                ## FTP 아이디
#PWD='1234'                ## FTP 패스워드
#REMOTE_DIR='/home/test'  ## 리모트디렉토리

#ftp -n -v $REMOTE << EOF  ## FTP 접속
#user $ID $PWD            ## LOGIN
#prompt
#bi                        ## binary 모드 변경

#put $DB_BACKUP_DIR/all_$DATE.sql $REMOTE_DIR/all_$DATE.sql
#bye                      ## 접속종료
#EOF



--------------------------------------------------------------------------------------------

:wq를 입력하여 저장한후

vi /etc/crontab 을 입력하면 cron설정을 수정할 수 있습니다.

0  5  *  *  *  root  /your/shell/file/dir/backup.sh

이렇게 입력하면 root 권한으로 메일 새벽 5시에 해당 쉘을 실행시키라는 의미입니다.

cron 파일을 수정한 후

# /etc/init.d/cron restart

명령으로 크론을 재기동해줍니다.

만든 쉘이 정상작동되는지 확인하려면 해당 경로에서

./backup.sh 로 강제실행 시킬 수 있습니다.
 
실행이 안되면 아래 명령어를 실행해 준다.
root#] chmod +x backup.sh

List of Articles
번호 제목 날짜 조회 수
177 find 명령어로 특정 디렉토리 내 특정 파일들의 특정 문자열 일괄 변경 2014.02.27 7195
176 find명령과 grep명령을 이용하여 파일안의 문자열 찾기 2014.02.27 7287
175 ftp passive mode 설정 2014.02.27 8095
174 history 파일 삭제 제한하기 2014.02.27 7788
173 hp Smart Array CLI 사용해서 논리드라이브 복구(Linux) 2015.06.16 9058
172 htaccess를 이용한 특정 디렉토리 접근 관리하기 2014.02.27 7136
171 htaccess를 이용한 특정 디렉토리 접근 관리하기 2014.02.27 7123
170 httpd.conf 기타 설정 사항 2015.07.16 7368
169 iconv 추가 설치 2014.03.26 8603
168 iptables + 스크립트를 이용한 중국 IP 차단 2014.02.27 8696
167 iptables GEOIP 모듈 설치. (국가별 IP 차단) 2014.02.27 7868
166 iptables 접속 차단 스크립트 2014.04.23 7665
165 iptable에서 TCP SYN Flooding 차단 설정 2014.02.27 9555
164 kernel panic 복구 2014.02.27 9321
163 libphp5.so: undefined symbol: unixd_config 2016.03.18 9577
162 LILO, GRUB root 패스워드 리셋 2014.02.27 7895
161 LINUX - 특정 파일이 속한 RPM 패키지 확인 및 설정 파일 경로 2014.02.27 7940
160 Linux LVM구성하기 2014.02.27 8218
159 linux mcrypt 설치 (php 재컴파일 필요) 2014.02.27 7824
158 Linux 사용자 계정 추가 및 도메인 연결과정 2014.02.27 7323
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 12 Next
/ 12

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved