Linux环境下Mysql数据表定时任务自动备份

                            1.1    Linux环境下Mysql数据表自动备份

1.1.1  查看磁盘使用情况

df -h

1.1.2  创建备份目录

# home的空间比较多一点,就使用这个吧
cd /home
mkdir backup
cd backup

1.1.3  创建备份shell脚本

#这里为本项目数据库名
vim prms.sh
#!/bin/bash
mysqldump -uroot -p123456 prms_dev > /home/backup/prms_dev_$(date +%Y%m%d_%H%M%S).sql

1.1.4   添加可执行权限

chmod u+x prms.sh

1.1.5  安装 crontab

#查看crontab是否安装
crontab -l
#no crontab for root  未安装
#安装crontab
yum -y install vixie-cron     # crontabs的核心依赖
yum install crontabs
#服务状态控制
/sbin/service crond start //启动服务 
/sbin/service crond stop //关闭服务 
/sbin/service crond restart //重启服务 
/sbin/service crond reload //重新载入配置 
/sbin/service crond status //查看状态
#或者使用
service crond start 
service crond stop 
service crond restart 
service crond reload 
service crond status
#开机启动
vim /etc/rc.d/rc.local
/sbin/service crond start

1.1.6  加入计划任务

crontab -e
#具体的cron表达式,请参考本人博客详解或者自行百度,这里不做详解
#这里先测试  意思是每过一分钟执行一次脚本
*/1 * * * * /home/backup/prms.sh

1.1.7  查看计划任务是否执行

#命令类似tomcat的日志查看
tail -f /var/log/cron

1.1.8  错误解决

错误1. mysqldump: 未找到命令
#详解
由于系统默认会查找/usr/bin下的命令,没有找到此条命令
#查找
find  / -name mysql -print
#软连接到/usr/bin
ln -fs /usr/local/mysql/bin/mysqldump /usr/bin
错误2.Enter password: mysqldump: Got error: 2002: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) when trying to connect
解决方案:原因是 mysql的存储目录更改,修改shell脚本,加上-h127.0.0.1
mysqldump -h127.0.0.1 -uroot -p123456 prms_dev > /home/backup/prms_dev_$(date +%Y%m%d_%H%M%S).sql
错误3. Warning: Using a password on the command line interface can be insecure.
解决方案:mysqldump -h127.0.0.1 prms_dev > /home/backup/prms_dev_$(date +%Y%m%d_%H%M%S).sql
注意:脚本中的用户名密码在mysql5.5之前的版本可以加入,根据官方文档说明在5.6以及以上版本,需要默认配置到my.ini文件中.
#打开mysql配置文件加入如下除注释的配置,账号密码自行修改.
vim my.ini
#mysql登录的账号密码,这里为记录,并非实际账号密码
[mysqldump]
user=root
password=123456

1.1.9  更新定时任务表达式

#这里更新为每天5:00和17:00执行任务
0 5,17 * * *

 

Linux环境下Mysql数据表定时任务自动备份_第1张图片

定时任务备份mysql数据库,已经完成. 配置中很多的坑,只要细心慢慢调试,很快就会解决,一起努力进步吧!


你可能感兴趣的:(mysql,linux)