메뉴 건너뛰기

조회 수 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

  1. Rocky Linux 8에 docker 설치하기

    Date2024.04.23 Views5
    Read More
  2. centos 7 APM 최신버전 설치 ( mariadb 10.4 / apache 2.4.39 / php 7.3.8 )

    Date2024.02.07 Views48
    Read More
  3. 작업 예약 스케줄러(크론Cron)파일,자동 백업 명령

    Date2023.01.12 Views133
    Read More
  4. No Image

    root 계정 su 명령 제한

    Date2023.01.20 Views145
    Read More
  5. No Image

    우분투 작업 스케줄러 Crontab 사용법, 디버깅, 주의 사항

    Date2023.01.12 Views154
    Read More
  6. 다중명령어(세미콜론(;), 파이프pipe(|), 더블 엔퍼센트 &&, ||)의미,사용법과 차이점

    Date2023.01.12 Views158
    Read More
  7. No Image

    find 명령어

    Date2021.03.26 Views162
    Read More
  8. 기본 허가권,퍼미션 지정(제어, 설정)하기(umask와 작동 원리)

    Date2023.01.12 Views166
    Read More
  9. No Image

    재지향시 유의사항 (grep 재지향)

    Date2021.03.26 Views185
    Read More
  10. No Image

    centos 시작시 네트워크 모듈 추가

    Date2021.03.26 Views207
    Read More
  11. No Image

    netstat 명령어

    Date2021.03.26 Views210
    Read More
  12. No Image

    crontab 사용법

    Date2021.03.26 Views248
    Read More
  13. 리눅스 vsftpd 500 OOPS 에러 (CENTOS 7)

    Date2020.03.04 Views298
    Read More
  14. CentOS ImageMagick 설치 php 연동

    Date2021.03.26 Views312
    Read More
  15. 명령어 모음

    Date2021.03.26 Views373
    Read More
  16. No Image

    tar.gz 파일 묶기, 압축하기, 압축 풀기

    Date2021.03.26 Views407
    Read More
  17. No Image

    centos7 sendmail 설치 및 세팅

    Date2020.12.31 Views470
    Read More
  18. No Image

    apache2 트래픽 모듈 mod_cband 사용법

    Date2019.02.14 Views1129
    Read More
  19. No Image

    이미지 및 파일 무단링크 방지책

    Date2019.02.14 Views1137
    Read More
  20. No Image

    php_screw를 이용한 php 소스 암호화 하기

    Date2019.02.14 Views1420
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 12 Next
/ 12

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved