數據庫的主從複製,負載均衡,讀寫分離什麼的好久之前就學過,本身玩了一下,不過一直缺乏實戰經驗,之前學的時候也就是跟着操做了一遍,過不久就忘記了,最近兼職作了個外包,客戶要求作數據庫備份,因而想寫一個shell腳原本定時備份數據庫,那麼問題了,好久沒有寫過腳本,爲何寫這麼個小東西折騰了頭天。 #如下爲我寫的腳本,還待完善 #!/bin/bash DATE=$(date +%Y%m%d_%H%M%S)mysql
BASE=/data/bak LOGFILE="$BASE/log/backup_$DATE.log" BACKUP="$BASE/sql/blog_$DATE.sql" echo "=============================$DATE===============================" >> $LOGFILE echo "start backup..." >> $LOGFILE /usr/local/mysql/bin/mysqldump -uroot -p111111 mysql > $BACKUP 2> $LOGFILE echo "end backup..." >> $LOGFILE find $BASE/sql/ -name "*.gz" -mmin +3 | xargs rm -f gzip $BACKUP 2> $LOGFILEsql
exitshell
加入定時任務 crontab -e */1 * * * * /data/bak/mysql_bak.sh 2> /data/bak/error.log #這裏講一下涉及到的知識和碰到的問題數據庫
gzip命令用來壓縮文件。gzip是個使用普遍的壓縮程序,文件經它壓縮事後,其名稱後面會多處「.gz」擴展名。 gzip是在Linux系統中常常使用的一個對文件進行壓縮和解壓縮的命令,既方便又好用。gzip不只能夠用來壓縮大的、較少使用的文件以節省磁盤空間,還能夠和tar命令一塊兒構成Linux操做系統中比較流行的壓縮文件格式。據統計,gzip命令對文本文件有60%~70%的壓縮率。減小文件大小有兩個明顯的好處,一是能夠減小存儲空間,二是經過網絡傳輸文件時,能夠減小傳輸的時間。 語法 gzip(選項)(參數) 選項 -a或——ascii:使用ASCII文字模式; -d或--decompress或----uncompress:解開壓縮文件; -f或——force:強行壓縮文件。不理會文件名稱或硬鏈接是否存在以及該文件是否爲符號鏈接; -h或——help:在線幫助; -l或——list:列出壓縮文件的相關信息; -L或——license:顯示版本與版權信息; -n或--no-name:壓縮文件時,不保存原來的文件名稱及時間戳記; -N或——name:壓縮文件時,保存原來的文件名稱及時間戳記; -q或——quiet:不顯示警告信息; -r或——recursive:遞歸處理,將指定目錄下的全部文件及子目錄一併處理; -S或<壓縮字尾字符串>或----suffix<壓縮字尾字符串>:更改壓縮字尾字符串; -t或——test:測試壓縮文件是否正確無誤; -v或——verbose:顯示指令執行過程; -V或——version:顯示版本信息; -<壓縮效率>:壓縮效率是一個介於1~9的數值,預設值爲「6」,指定愈大的數值,壓縮效率就會愈高; --best:此參數的效果和指定「-9」參數相同; --fast:此參數的效果和指定「-1」參數相同。 參數 文件列表:指定要壓縮的文件列表。 實例 把test6目錄下的每一個文件壓縮成.gz文件 gzip * 把上例中每一個壓縮的文件解壓,並列出詳細的信息 gzip -dv * 詳細顯示例1中每一個壓縮的文件的信息,並不解壓 gzip -l * 壓縮一個tar備份文件,此時壓縮文件的擴展名爲.tar.gz gzip -r log.tar 遞歸的壓縮目錄 gzip -rv test6 這樣,全部test下面的文件都變成了*.gz,目錄依然存在只是目錄裏面的文件相應變成了*.gz.這就是壓縮,和打包不一樣。由於是對目錄操做,因此須要加上-r選項,這樣也能夠對子目錄進行遞歸了。 遞歸地解壓目錄 gzip -dr test6 4. find找出一些之前的備份文件刪除,省得日誌文件佔空間,這裏也擴展一下知識 find [目錄] 選項 [文件名] -mtime[以小時算] -mmin[以分鐘算] +數字 文件mtime的時間加上+的時間若是小於當前時間則被篩選出來,xarg篩選結果逐個處理刪除 5. 剛開始寫定時任務不起做用,不知道什麼緣由,實在納悶,最後重定向錯誤時間到日誌文件才發現緣由,原來腳本里面的路徑我寫的是相對路徑,致使找不到文件出錯,後來才把BASE給加上去的bash
#不過還有遺留問題,就是目前日誌文件都變爲空文件了,待解決網絡
到技術羣裏問了一下,終於找到問題了,2>重定向直接覆蓋了文件,改爲2>>追加就行了,折騰了很久,呵呵負載均衡