Linux实现定时备份MySQL数据库并删除30天前的备份文件
程序员文章站
2022-06-12 18:30:29
1. mysql5.6以上版本
2. 修改 /etc/my.cnf 文件
# vim /etc/my.cnf
[client]
host=localhost
user...
1. mysql5.6以上版本
2. 修改 /etc/my.cnf 文件
# vim /etc/my.cnf [client] host=localhost user=你的数据库用户 password='你的数据库密码'
3. 编写数据库脚本 mysql-backup.sh
# vim mysql-backup.sh #!/bin/bash backupdir=数据库备份目录 backuptime=`date +%y%m%d%h%m%s` mysqldump 你的数据库 | gzip > $backupdir/你的数据库-$backuptime.sql.gz echo "1."$backuptime "备份完成" >> #backupdir/mysql.log cd $backupdir rm -rf `find . -name '*.sql.gz' -mtime +30` >> #backupdir/mysql.log 2>&1 #删除30天前备份文件 echo "2.删除30天前的备份文件完成" >> #backupdir/mysql.log
4. 为脚本添加执行权限
# chmod +x mysql-backup.sh
5. 测试执行
./mysql-backup.sh
6. 添加定时计划
# crontab -e (和vim编辑器一样) # crontab配置文件格式:分 时 日 月 周 命令 # 在最后一行中加入: 0 3 * * * /usr/sbin/mysql-bakup.sh #表示每天3点00分执行备份 0 */6 * * * /usr/sbin/mysql-bakup.sh #表示每6个小时执行备份
7. 重启crontab
# /etc/rc.d/init.d/crond restart
8. 恢复数据库备份文件
#sql备份文件恢复: mysql -u root -p 你的数据库 < 备份文件名.sql #压缩文件恢复: gzip < 备份文件名.sql.gz | mysql -u root -p 你的数据库
9. 附:如果出现问题:"mysqldump: command not found",解决如下:
ln -fs /usr/local/mysql/bin/mysqldump /usr/bin ln -fs /usr/local/mysql/bin/mysql /usr/bin
ps:下面看下linux中备份mysql数据库
在linux中备份mysql数据库,命令是:
[root]# mysqldump -u 用户名 -p 密码 --all-databases > /home/mysql/bak.sql
如果报错就添加如下:
mysqldump -h localhost -u root -p psword root@172.16.123.88 --all-tablespaces --master-data=2 --events --routines --all-databases > /home/mysql/mydatas.sql
简单版的:(先保存在本地)
mysqldump -u root -p databasename > data.sql
查询mysql数据库:whereis mysql
进入数据库(当前数据库文件本地):mysql -h localhost -u 数据库账号 -p 密码
查看数据库:show databases;
查看文件大小:ls -lht
总结
以上所述是小编给大家介绍的linux实现定时备份mysql数据库并删除30天前的备份文件,希望对大家有所帮助
推荐阅读
-
linux定时备份MySQL数据库并删除以前的备份文件(推荐)
-
Linux实现定时备份MySQL数据库并删除30天前的备份文件
-
Linux下通过脚本自动备份Oracle数据库并删除指定天数前的备份
-
Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录
-
linux每天定时备份数据库并删除十天前数据详细步骤
-
Linux实现定时备份MySQL数据库并删除30天前的备份文件
-
linux定时备份MySQL数据库并删除以前的备份文件(推荐)
-
linux定时备份MySQL数据库并删除七天前的备份文件 (2014
-
linux实现定时备份mysql数据库的简单方法
-
Linux下自动备份Oracle数据库并删除指定天数前的备份