Shell脚本-----自动备份Mysql数据库

脚本的整体思路

1.定义需要的变量

2.利用for循环备份需要备份的库,并以库名-当天日期.sql命名,并记录相关日志

3.建立备份当天的日期的目录,向备份的Sql文件移动到该目录

4.压缩打包该目录,以节省空间,打包成功后删除该目录

5.备份目录只备份七天的数据库,第八天删除第一天的备份,目录只会存在连续七天的备份文件

6.查找备份目录下的.log日志文件,超过七天的删除

#!/bin/bash

mysql_bin=/usr/local/tdoa/mysql/bin/mysqldump
user=root
passwd=myoa888
mysql_back=/mysql-back
date=$(date +%F)
for i in td_oa td_oa_archive  bus crscell
do
        $mysql_bin -u$user -p$passwd $i >> $mysql_back/$i-$date.sql
        if [ $? -eq 0 ];then
                        echo -e "$date $i Back Success\n" >> $mysql_back/back.log
                else
                        echo -e "$date $i Back Failure\n" >> $mysql_back/error.log
        fi
done

cd $mysql_back

        if [ ! -d $date ];then
                mkdir $mysql_back/$date
                mv $mysql_back/*.sql $mysql_back/$date
        else
                mv $mysql_back/*.sql $mysql_back/$date
        fi

tar -czf mysql-$date.tar.gz $date
rm -r $mysql_back/$date

find $mysql_back -name \*.gz -type f -mtime +6 -exec rm {} \;
find $mysql_back -name \*.log -type f -atime +6 -exec rm {} \;

Shell脚本-----自动备份Mysql数据库,布布扣,bubuko.com

时间: 2024-12-25 22:59:14

Shell脚本-----自动备份Mysql数据库的相关文章

SHELL 自动备份MYSQL数据库(备份单个数据库及所有数据库)

SHELL 自动备份MYSQL数据库 备份单个数据库及所有数据库 楓城浪子原创,转载请标明出处! 更多技术博文请见个人博客:https://fengchenglangzi.000webhostapp.com 微信bh19890922 QQ445718526.490425557 部分截图: 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657

如何在生产环境下实现每天自动备份mysql数据库

1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢?我相信大家都想让它自动备份,接下来我通"shell脚本+定时任务"的方式来实现自动备份mysql数据库. 2.环境 备份路径:/data/mysqlbak/ 备份脚本:/data/mysqlbak/mysqlbak.sh 备份时间:每天23:59备份 备份要求:比如备份的数据只保留1周

Linux 每天自动备份mysql数据库的方法

Linux 每天自动备份mysql数据库的方法 作者: 字体:[增加 减小] 类型:转载 linux下为了安全有时候需要自动备份mysql数据库,下面是具体的实现步骤. /usr/bin为mysql安装目录 建备份文件夹: mkdir mysql_data_bak 建脚本文件: touch autobackupmysql.sh 打开文件 vi autobackupmysql.sh 在脚本中加入如下内容: filename=`date +%Y%m%d` /usr/bin/mysqldump -op

CentOS下每天自动备份mysql数据库

每天自动备份mysql数据库的脚本,并且自动发送到你指定的邮箱面,这样vpser再也不会为丢失数据烦恼啦. mysqldump -uuser -ppassword –databases db1 db2 db3 > /home/website/backups/databackup.sql tar zcf /home/website/backups/databackup.sql.tar.gz /home/website/backups/ echo "主题:数据库备份" |mutt  

自动备份mysql数据库并发送到Email方法

一个博客,一个网站最重要的就是数据库,所以经常备份数据是必须的.尽管 WordPress 有定时备份数据的插件,但只能备份当前的博客,不够灵活.适合个人小小博客,对于一些网站来说,就不适合了.现在很多人都拥有多个网站,showfom 同学就有几个网站.每个网站都装个插件就比较麻烦了.况且不是每个网站都是 WordPress 的 . 所以写了个自动备份mysql数据库的脚本,再加上gmail这个G级邮箱,备份多少数据都可以了...下面是代码: mysqldump -uuser -ppassword

一个自动备份mysql数据库的bat文件内容

自动备份mysql数据库,并已当前的日期时间为目录 copy过去, xcopy将近15年没有用dos命令,还是这么亲切 另 本方法是备份数据库文件,不是dump导出,然后再计划任务中使用,我用的是wamp,其他的环境类似的改改即可 ====dbback.bat============ NET STOP wampapacheNET STOP wampmysqldset /a t1=(1%time:~0,2%-100)*1if %t1% LSS 10 set t1=0%t1%set ymd_hms=

SHELL脚本自动备份Linux系统

今天来写一个使用shell脚本增量备份系统文件,顺便复习一下shell脚本相关的命令,这个脚本可以根据自己的需求来备份不同的文件或者文件夹,进行完整备份和增量备份.直接上脚本如下: #!/bin/sh #Automatic Backup Linux System Files #Author wugk 2013-11-22 #Define Variable SOURCE_DIR=( $* ) TARGET_DIR=/data/backup/ YEAR=`date +%Y` MONTH=`date

使用shell脚本实现自动备份MySQL数据库

192.168.1.2服务器对192.168.1.1服务器上的MySQL数据库进行备份. 必须满足的条件: 1.在192.168.1.1服务器上创建专门用来备份的数据库账号,并赋予相应的权限: mysql> grant select,lock tables on *.* to 'operator'@'192.168.%.%' identified by '123456'; #备份数据库需要账号具有查看表和锁定表的权限 2.在192.168.1.2服务器上使用该账号进行手工备份,测试是否可以备份成

shell学习之自动备份mysql数据库

首先登陆mysql: mysql -u root -p 注意:不是系统root的密码,mysql安装好后默认root密码为空 >set password for 'root'@'localhost' = password('*****'); --修改root用户的本地密码 >grant all on zabbix.* to [email protected]'localhost' identified by "123456"; ---创建备份zabbix数据库的用户和密码,