Shell 編程綜合案例

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章