博客
关于我
使用shell脚本计划任务备份mysql数据库
阅读量:664 次
发布时间:2019-03-15

本文共 1413 字,大约阅读时间需要 4 分钟。

1. 创建数据库

在这里插入图片描述

2. 设置远程访问权限

mysql> grant all on student.* to 'bob'@'192.168.100.60' identified by 'pwd@123';Query OK, 0 rows affected (0.01 sec)mysql> grant all on teacher.* to 'bob'@'192.168.100.60' identified by 'pwd@123';Query OK, 0 rows affected (0.00 sec)

在这里插入图片描述

3. 安装客户端MySQL

[root@centos06 ~]# yum -y install mariadb

在这里插入图片描述

4. 测试远程访问连接

[root@centos06 ~] mysqldump -ubob -ppwd@123 -h 192.168.100.30 --databases student > test.sql[root@centos06 ~] ls -lh test.sql

在这里插入图片描述

5. 创建备份目录

[root@centos06 ~]mkdir -p /mysql/data_bak/

在这里插入图片描述

6. 编写shell 脚本

#!/bin/bash#数据库逻辑备份#定义数据库连接、目标库信息USER ="bob"PASS="pwd@123"POST="192.168.100.30"CONN="-u $USER -p $PASS -h $POST"DB1="student"DB2="teacher"#定义备份目录DIR="/mysql/data_bak/"DUMP="/usr/local/mysql/bin/mysqldump"TIME=`date +%Y%m%d-%H%H`BAK_NAME1="$DB1-$TIME"BAK_NAME2="$DB3-$TIME"#导出sql脚本,进行打包cd $DIR$DUMP $CONN --databases $DB1 > $BAK_NAME1.sql$DUMP $CONN --databases $DB2 > $BAK_NAME2.sql/usr/bin/tar zcf $BAK_NAME1.tar.gz $BAK_NAME1.sql --remove &> /dev/null/usr/bin/tar zcf $BAK_NAME2.tar.gz $BAK_NAME2.sql --remove &> /dev/null

在这里插入图片描述

7. 添加脚本执行权限

[root@centos06 ~]# chmod +x mysql_bak.sh

在这里插入图片描述

8. 手动执行脚本测试

[root@centos06 ~]# ./mysql_bak.sh [root@centos06 ~]# ls -lh /mysql/data_bak/

在这里插入图片描述

9. 移动脚本到备份目录

[root@centos06 ~]# mv mysql_bak.sh /mysql/data_bak/[root@centos06 ~]# ls /mysql/data_bak/

在这里插入图片描述

10. 设置计划任务执行备份文件,每天凌晨4.50备份数据库

[root@centos06 ~]# crontab -e50      4       *       *       *       /mysql/data_bak/mysql_bak.sh

在这里插入图片描述

转载地址:http://qcemz.baihongyu.com/

你可能感兴趣的文章
mysql实现成绩排名
查看>>
Mysql客户端中文乱码问题解决
查看>>
mysql导入数据库出现:Incorrect string value: '\xE7\x82\xB9\xE9\x92\x9F' for column 'chinese' at row 1...
查看>>
Mysql工作笔记006---Mysql服务器磁盘爆满了_java.sql.SQLException: Error writing file ‘tmp/MYfXO41p‘
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能优化
查看>>
MySQL性能优化必备25条
查看>>
Mysql性能优化(3):分析执行计划
查看>>
MySQL性能测试及调优中的死锁处理方法
查看>>