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