zoukankan      html  css  js  c++  java
  • Shell备份数据库

    对数据库进行定时备份,保留7天内的数据。
    代码如下:

    #!/bin/bash
    export LANG=en_US.UTF-8
    BakDir=/usr/local/app/backup/db/
    if [ ! -d $BakDir ];then
    	mkdir -p $BakDir
    else
    	echo "文件夹已存在"
    fi
    LogFile=/usr/local/app/backup/backup.log
    if [ ! -f $LogFile ];then
    	LogPath=/usr/local/app/backup
    	cd $LogPath
    	touch backup.log
    else
    	echo "日志文件已存在"
    fi
    Begin=`date +"%Y年%m月%d日 %H:%M:%S"`
    cd $BakDir
    GZDumpFile=senseface_dump_$(date +%Y%m%d).tgz
    read -p "输入要备份的数据库:" database
    read -p "输入数据库ip:" host
    read -p "输入数据库port:" port
    read -p "输入数据库密码:" password
    read -p "输入要备份的表,格式如:a(表名1),b(表名2):" tables
    OLD_IFS="$IFS" #保存旧的分隔符
    IFS=","
    array=($tables)
    IFS="$OLD_IFS" # 将IFS恢复成原来的 
    for db in ${database[@]};do
    	for i in "${!array[@]}"; do
    		/usr/bin/mysqldump -h $host -P $port -uroot -p$password $db ${array[i]} > $BakDir/"${array[i]}"_dump_$(date +%Y%m%d).sql
    		done
    	done
    if [ -e $GZDumpFile ];then
    	rm -f $GZDumpFile
    	tar -czvf $GZDumpFile *.sql
    else
    	rm -f $GZDumpFile
    	tar -czvf $GZDumpFile *.sql
    fi
    rm *.sql
    
    #只保留过去7天的数据库内容
    find $BakDir -name "*.tgz" -mtime +7 | xargs rm -f
    
    Last=`date +"%Y年%m月%d日 %H:%M:%S"`
    echo 开始:$Begin 结束:$Last $GZDumpFile succ >> $LogFile
    
    
    

    第一次尝试写Shell语言,有点慌。

  • 相关阅读:
    c# 数组自定义排序
    我的第一个npm包:wechat-menu-editor 基于Vue的微信自定义菜单编辑器
    vue-element-admin左侧目录的三级展示
    vue的input框输入不了
    常用IDE(开发工具)
    DOM – 大杂烩
    Glob 语法
    Tailwind CSS – 学习笔记
    Google Ads – 大杂烩
    Webpack 学习笔记
  • 原文地址:https://www.cnblogs.com/zhouzetian/p/13380535.html
Copyright © 2011-2022 走看看