MySql在linux下的自動備份

來源:互聯網
上載者:User

Mysql在windows下可藉助於MySQL Administrator來完成定期備份,而在Linux下就比較麻煩,沒有現成的,就只能自己寫了。

1、建立一個mysql.sh,裡面輸入
!/bin/sh
#backup mysql database

#delete file
find /usr/local/backup/mysql -type f -mtime +7 -exec rm {} \;

rq=`date +%Y%m%d%H%M`
#backup each database
for db in `echo “show databases” | /usr/local/mysql/bin/mysql -uroot -p654123 |grep -v Database`;
do
echo $db;
/usr/local/mysql/bin/mysqldump -q -a -c -uroot -pXXXX $db |gzip > `echo “/usr/local/backup/mysql/other_db($db)_$rq.sql.gz”`
done

大概思路是先刪除7天前的備份檔案,以免硬碟空間被佔用過多,而後遍曆所有資料庫,進行逐一備份,備份檔案自己會進行壓縮,以節省空間的。
檔案中目錄名稱、密碼請根據自己的情況進行修改。

2、變更檔屬性,使其可以執行
#chmod +x mysql.sh

3、現在如果手工執行該檔案,就可以完成備份,不過我們的目的是能夠讓系統自動定期備份,所以還需要藉助linux的crontab功能。
#vi /etc/crontab
  在下面添加
  01 3 * * * root /usr/sbin/mysql.sh
  表示每天3點鐘執行備份,檔案名稱請自行修改
4、重新啟動crond
  # /etc/rc.d/init.d/crond restart
這樣就可以了,每天就可以在備份目錄下看到備份檔案

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.