在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
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. 测试执行
6. 添加定时计划 # crontab -e (和vim编辑器一样) # crontab配置文件格式:分 时 日 月 周 命令 # 在最后一行中加入: 0 3 * * * /usr/sbin/mysql-bakup.sh #表示每天3点00分执行备份 0 */6 * * * /usr/sbin/mysql-bakup.sh #表示每6个小时执行备份 7. 重启crontab
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 [email protected] --all-tablespaces --master-data=2 --events --routines --all-databases > /home/mysql/mydatas.sql 简单版的:(先保存在本地) mysqldump -u root -p databaseName > data.sql 查询mysql数据库: 进入数据库(当前数据库文件本地): 查看数据库: 查看文件大小: 总结 以上所述是小编给大家介绍的Linux实现定时备份MySQL数据库并删除30天前的备份文件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对极客世界网站的支持! |
请发表评论