博客
关于我
使用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/

你可能感兴趣的文章
Nginx配置Https证书
查看>>
Nginx配置http跳转https
查看>>
Nginx配置ssl实现https
查看>>
nginx配置ssl证书https解决公网ip可以访问但是域名不行的问题
查看>>
Nginx配置TCP代理指南
查看>>
NGINX配置TCP连接双向SSL
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
查看>>
nginx配置中的服务器名称
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置后台网关映射路径
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>
Nginx配置多个不同端口服务共用80端口
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-动静分离实例:搭建静态资源服务器
查看>>
Nginx配置实例-反向代理实例:根据访问的路径跳转到不同端口的服务中
查看>>
Nginx配置实例-反向代理实现浏览器请求Nginx跳转到服务器某页面
查看>>