Shell 編程綜合案例
Shell也學習了大概的知識,現在這篇文章就大概講述下如何使用shell編寫一個腳本呢?下面就展示一個大家常用的數據庫備份案例來進行展示。
需求分析
- 1)每天凌晨2:10分備份數據庫 atguiguDB 到 /data/backup/db
- 2)備份開始和備份結束能夠給出相應的提示信息
- 3)備份後的文件要求以備份時間爲文件名,並打包成 .tar.gz 的形式,比如
2018-03-12_230201.tar.gz - 4)在備份的同時,檢查是否有10天前備份的數據庫文件,如果有就將其刪除
編寫一個shell腳本
思路分析
先將mysql數據庫備份到文件夾下打包。然後在用crond進行定時執行
代碼實現
#!/bin/bash
#完成數據庫的定時備份
#備份的路徑
BACKUP=/data/backup/db
#當前的時間作爲文件名
DATETIME=$(date +%Y-%m-%d_%H%M%S)
#可以輸出變量調試
#echo ${DATETIME}
echo "=========開始備份=========="
echo "========備份的路徑是 $BACKUP/$DATETIME.tar.gz=========="
#主機
HOST=localhost
#用戶名
DB_USER=root
#密碼
DB_PWD=root
#備份數據庫名
DATABASE=atguiguDB
#創建備份的文件夾
#如果該備份的文件夾有則使用,沒有就重新創建一個 -p:參數P代表parents,表示遞歸創建目錄如果要創建目錄A並創建目錄A的子目錄B,沒有用-p的情況下是mkdir 2次。如果用-p 可以直接創建2個目錄 mkdir -p 目錄A/子目錄B就可以。
[ ! -d "$BACKUP/$DATETIME"] && mkdir -p "$BACKUP/$DATETIME"
#執行mysql的備份數據庫的指令
mysqldump -u${DB_USER} -p${DB_PWD} --host=$HOST $DATABASE | gzip >$BACKUP/$DATETIME/$DATETIME.sql.gz
#打包備份文件
cd $BACKUP
tar -zcvf $DATETIME.tar.gz $DATETIME
# 刪除臨時目錄
rm -rf $BACKUP/$DATETIME
#刪除10天前的備份文件
find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm -rf {} \;
echo "======備份文件成功====="
crond 定時執行
10 2 * * * /usr/sbin/mysql_db_backup.sh