linux 自動備份腳本

首先我在/root/backup 目錄下創建一個文件夾,html

  #mkdir /root/backup/mysqlbackupmysql

  之後在天天五點鐘,就會有一個文件保存在這裏.linux

  接着新建文件web

  #vim /root/mysqlautobaksql

  輸入:shell

  filename=` date +%Y%m%d `數據庫

  mysqldump --all-databases -uroot -p(mysql密碼)> /root/backup/mysqlbackup/mysql$file.sqlvim

  

  保存退出!bash

  讓它能夠執行服務器

  #chomd +X /root/mysqlautobak

  接着開始完crontab了

  #vi /etc/crontab

  

  添加一行

  

  01 5 * * * root /root/mysqlautobak

  保存退出.

  從新啓動你的crond服務進程

  # /etc/rc.d/init.d/crond restart


===============================================================================

hp unix 自動全備份腳本(shell)
                                      

說明:天天夜裏10點自動備份而且壓縮,保留2天備份,在備份完當天後刪除前天的備份。在一切執行以後,發郵件通知,郵件內容有刪除文件和備份文件名稱及備份開始時間,結束時間。
使用方法:nohup backup.sh &

filename:backup.sh
reportlist=""
while [ 1 ]
do
hou=`date +%H`
backdate=`date +%Y%m%d`
if [ $hou -eq 22 ]
then
begintime=`date +%Y-%m-%d:%H-%M`
cd /data_log2/for_test
log_txt=`ls -al -crt log.txt | awk '{print $9}' | wc -l`
if [ $log_txt -gt 0 ]
then
        mv log.txt log.txt.bak
fi

exp owner=user file=/data_log2/for_test/tmp_now.dmp
compress /data_log2/for_test/tmp_now.dmp
mv tmp_now.dmp.Z report_$backdate.dmp.Z
echo "---------report database backuped----------- ">> log.txt
echo "filename="report_$backdate.dmp.Z >>log.txt

delfile=`ls -al -crt *.Z | awk '{print $9}' | head -1`
count=`ls -al -crt *.Z | awk '{print $9}' | wc -l`

if [ $count -gt 2 ]
then
        rm `ls -al -crt *.Z | awk '{print $9}' | head -1`
        echo "----------- old backup deleted ---------" >> log.txt
        echo "the deleted backup filename="$delfile >> log.txt
fi

echo "-----------------beigin time----------------" >> log.txt
echo $begintime >> log.txt
echo "-----------------end    time----------------" >> log.txt
echo `date +%Y-%m-%d:%H-%M` >> log.txt

rm log.txt.bak

mailx -s "10.203.116.23 daily database backup" -r ")" $reportlist < log.txt
fi

sleep 3600
done

======================================================================================
1 給我本身的服務器寫的一段自動備份的shell 
#!/bin/bash

#指定要備份的系統目錄 
SYSTEM_DIR=/home

#指定要備份的目錄MAIL_DIR=mailbox       #郵件目錄 
WEBSITE_DIR=www/html                    #WEB目錄 
DATABASE_DIR=databases                  #數據庫目錄

#指定備份文件的前綴 
MAIL_PREFIX=mail 
WEBSITE_PREFIX=web 
DATABASE_PREFIX=database

#有朋友的一臺WIN2K服務器,我在上面開了ftp,把備份文件傳到他的服務器上,至關於我實現了個雙機備份

#ftp服務器的IP 
FTP_SERV=211.144.155.111 
#ftp用戶名 
FTP_USER=username 
#ftp密碼 
FTP_PASS=12345678

#備份文件存放目錄 
BACKUP_DIR=/home/backup

#格式化一下日期,備份文件時用日期來作文件名的 
DATE=`date +%Y%m%d`

#開始備份郵件 
if [ -f ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ]; then #若是當天的郵件已經備份,那沒跳過 
    echo `date +%Y-%m-%d`'s mail backup file is existing 
else #若是沒有備份,那麼用tar命令來打包郵件目錄 
    tar -czvf ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${MAIL_DIR} 
fi

#開始備份網站目錄,備份過程同上 
if [ -f ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ]; then 
    echo `date +%Y-%m-%d`'s webebsite backup file is existing 
else 
    tar -czvf ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${WEBSITE_DIR} 
fi

#開始備份數據庫目錄,備份過程同上 
if [ -f ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ]; then 
    echo `date +%Y-%m-%d`'s database backup file is existing 
else 
    tar -czvf ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${DATABASE_DIR} 
fi

#開始把備份文件傳輸到另外一臺服務器上 
ftp -i -n $FTP_SERV <<AUTO_FTP 
user $FTP_USER $FTP_PASS 
passive 
binary 
put ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ${MAIL_PREFIX}${DATE}.tar.gz 
put ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ${WEBSITE_PREFIX}${DATE}.tar.gz 
put ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ${DATABASE_PREFIX}${DATE}.tar.gz 
AUTO_FTP

別忘了,還有最後一步,就是在crontab里加上個任務,這樣你就不用每次備份都一步步地敲那些瑣碎的命令了。


個人網站,但願你們多多交流 

===================================
linux下:

MySQL :: Linux 下自動備份數據庫的 shell 腳本 
Linux 服務器上的程序天天都在更新 MySQL 數據庫,因而就想起寫一個 shell 腳本,結合 crontab,定時備份數據庫。其實很是簡單,主要就是使用 MySQL 自帶的 mysqldump 命令。

腳本內容以下: 
#!/bin/sh 
# File: /home/mysql/backup.sh 
# Database info 
DB_NAME="test" 
DB_USER="username" 
DB_PASS="password"

# Others vars 
BIN_DIR="/usr/local/mysql/bin" 
BCK_DIR="/home/mysql/backup" 
DATE=`date +%F`

# TODO 
$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS $DB_NAME | gzip > $BCK_DIR/db_$DATE.gz


而後使用將此腳本加到 /etc/crontab 定時任務中:

01 5 * * 0 mysql /home/mysql/backup.sh

好了,每週日凌晨 5:01 系統就會自動運行 backup.sh 文件備份 MySQL 數據庫了。

/home/www/inc/back

相關文章
相關標籤/搜索