선도 및 데이터베이스 자동 백업 및 문자, 메일 알림 스크립트

5763 단어
1. SMTP 서버 추가
bin/mail은 기본적으로 로컬sendmail로 메일을 보내고, 프로필을 수정하면 외부 SMTP 서버를 사용할 수 있으며, sendmail을 사용하지 않고 외부 smtp 서버로 메일을 보내는 목적을 달성할 수 있습니다.
자동 경보를 보내야 하는 서버에서 아래 파일을 수정하고 아래 두 줄을 추가합니다
# vim /etc/mail.rc

set [email protected] smtp=smtp.126.com
set smtp-auth-user=doteyplay smtp-auth-password=*** smtp-auth=login
 redhat , /etc/mail.rc smtp , , ubuntu /etc/mail.rc 
buntu :
ubunut mailx deb bsd-mailx
bsd-mailx /etc/mail.rc centos 
apt-get install sendmail
apt-get install mailutils
apt-get install bsd-mailx

때때로 위쪽을 설정했는데 echo가 메일을 받을 때 메일을 받을 수 없습니다. 이때 서버에 문제가 있는 것이 아니라 스팸메일에 의해 지워졌을 수도 있습니다. 만약에 126의 smtp 서버로 텐센트와sina에 보내면 550의 오류가 발생합니다. (서버에서 메일에서 보기) 텐센트는 단체로 대량의 메일을 보냈다고 합니다. 설령 당신이 새로 신청하더라도 이 오류가 발생합니다.한편sina는 직접적으로'환불 원인: 외부 IP의 역사적 신뢰도가 낮다'는 이유로 이전에 테스트한 것이 너무 많아서 이 문제를 일으켰을 가능성이 높다.하지만 126을 직접 보내면 문제없다.그래서 단위 테스트 환경에 문제가 있고, 부서가 온라인에 도착했을 때 반드시 문제가 있는 것은 아니다
물론 이곳의 SMTP 서버도 다른 것을 사용할 수 있습니다. 예를 들어 QQ를 사용할 수 있지만 QQ는 몇 괘만 보낼 수 있습니다. 테스트를 할 때 항상 오류를 보고합니다. smtp-server: 454 Error: authentication failed, system busy, 만악의 TX입니다!그래서 나중에 126의 SMTP 서버를 고쳤는데 사용하기에 상당히 좋다.메일박스에 대해서는 139메일박스를 사용하세요. 문자 알림이 있어서요. 마찬가지로 테스트할 때 QQ메일박스가 느려요...
2. 선도 자동 백업 스크립트
1. 자동 백업 스크립트
     #vim chandao_backup.sh

     #!/bin/bash
     #Auto backup for chandao
     #Date: first write on 2014.7.22
     #Vertion: v1.1

     date=`date +%Y-%m-%d`
     tarball="tar -jcf /opt/backup/chandao-$date.tar.bz2 chandao/"
     [email protected]
     [email protected]

     if [ ! -d "/opt/backup/" ]; then
             mkdir -p /opt/backup/
     fi

     cd /var/www/html/ && $tarball
     judge=`echo $?`

     if [ $judge == 0 ];then
             echo "backup is ok" | mail -s "Auto backup for chandao" $user1 $user2;
     else
             echo "backup is failure" | mail -s "Auto backup for chandao" $user1 $user2;
     fi

     find /opt/backup/ -type f -mtime +30 -name "*.bz2" -exec rm -rf {} \;

2. 스크립트 실행 권한 부여
chmod +x chandao_backup.sh

2. 작업 계획 자동 실행
 #crontab -e
     0 0 * * * /bin/sh /opt/scripts/chandao_backup.sh > /dev/null 2>&1

3. 데이터베이스 자동 백업 스크립트
1. 자동 백업 스크립트
    #vim db_backup.sh

     #!/bin/bash
     #Auto backup for mariadb
     #Date: first write on 2014.7.22
     #Vertion: v1.1

     date=`date +%Y-%m-%d`
     datadir="tar -jcf /opt/backup/datadir-$date.tar.bz2 /data"
     #alldb="mysqldump --all-databases > /opt/backup/alldb-$date.sql"
     #zentaodb="mysqldump --databases zentao > /opt/backup/zentao-$date.sql"
     [email protected]
     [email protected]

     if [ ! -d "/opt/backup/" ]; then
             mkdir -p /opt/backup/
     fi

     mysqldump --all-databases > /opt/backup/alldb-$date.sql && mysqldump --databases zentao > /opt/backup/zentao-$date.sql
     judge=`echo $?`

     if [ $judge == 0 ];then
             cd /opt/backup/ && tar -jcf ALLDB-$date.tar.bz2 alldb-$date.sql zentao-$date.sql --remove-files
             $datadir;
             judge1=`echo $?`
             if [ $judge1 == 0 ];then
                     echo "Backup is ok!" | mail -s "Auto backup for db" $user1 $user2;
             else
                     echo "Db is ok but datadir is failure!" | mail -s "Auto backup for db" $user1 $user2;
             fi
     else
             echo "Backup is failure,because of db backup is faild!" | mail -s "Auto backup for db" $user1 $user2;
     fi

     find /opt/backup/ -type f -mtime +30 -name "*.bz2" -exec rm -rf {} \;

2. 스크립트 실행 권한 부여
chmod +x db_backup.sh

3. 작업 계획 자동 실행
#crontab -e
0 0 * * * /bin/sh /opt/scripts/db_backup.sh > /dev/null 2>&1

4. 스크립트 버전 업데이트:
데이터베이스 백업 스크립트 v1.2
#!/bin/bash
    #Auto backup for mariadb
    #Date: first write on 2014.7.22
    #Vertion: v1.2

    date=`date +%Y-%m-%d`
    [email protected]
    [email protected]
    main(){
            tar -jcf /opt/backup/datadir-$date.tar.bz2 /data;
            if [ $? -eq 0 ];then
                    /usr/local/mysql/bin/mysqldump --all-databases > /opt/backup/alldb-$date.sql;
                    if [ $? -eq 0 ];then
                            sleep 2
                            /usr/local/mysql/bin/mysqldump --databases zentao > /opt/backup/zentao-$date.sql;
                            if [ $? -eq 0 ];then
                               cd /opt/backup/
                               tar -jcf ALLDB-$date.tar.bz2 alldb-$date.sql zentao-$date.sql --remove-files \
                               && echo "Backup is ok!" | mail -s "Auto backup for db" $user2;
                            else
                               echo "Zentao db backup failure" | mail -s "Auto backup for db" $user2;
                            fi
                    else
                            echo "All databases backup failure" | mail -s "Auto backup for db" $user2;
                    fi
            else
                    echo "Datadir backup failure,it's first step" | mail -s "Auto backup for db" $user2;
            fi

            find /opt/backup/ -type f -mtime +30 -name "*.bz2" -exec rm -rf {} \;
    }


    if [ ! -d "/opt/backup/" ]; then
            mkdir -p /opt/backup/;
            main;
    else
            main;
    fi

다음으로 전송:https://blog.51cto.com/nmshuishui/1529829

좋은 웹페이지 즐겨찾기