使用mysqldump命令来备份(linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解)
使用mysqldump命令来备份
linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解目录
- 一、遇到的问题
- 二、思路
- 三、代码
一、遇到的问题
我们使用过mysqldump都知道,使用该命令后,需要我们手动输入 mysql的密码,那么我们就不能够直接在crontab中使用mysqldump实现周期备份。其实我们可以使用expect脚本自动输入密码,从而实现真正的周期备份。如果你不知道什么是expect,建议先请看这篇文章:http://www.zzvips.com/article/141303.html
二、思路
- 创建一个utils文件,里面存放shell脚本,包括mysqldump、scp等命令
- 使用expect脚本,执行utils内的脚本,并为其自动输入密码
- 最后使用驱动脚本,执行expect,在该脚本里面传入需要的参数
思路如下:
三、代码
3.1、单机冷备份
(1)mysqldump的shell脚本
backup.sh:
|
#!/bin/bash mysql_username=$1 backup_databases=$2 backup_path=$3 mysqldump -u ${mysql_username} -p --databases ${backup_databases} > ${backup_path} |
(2)执行mysqldump的expect脚本,能帮助我们自动输入mysql代码
single_cold_backup_service.exp:
|
#!/usr/bin/expect set timeout 5 #设置本机信息 set mysql_username [lindex $argv 0] set backup_database [lindex $argv 1] set backup_path [lindex $argv 2] #utils路径 set utils_path /home/hadoop/backup_script/utils spawn bash ${utils_path} /backup .sh ${mysql_username} ${backup_database} ${backup_path} expect { "*assword*" {send "nimabidecao1 " } #输入密码 } expect eof |
(3)驱动脚本,执行expect,这里可以传入需要的参数
single_cold_backup_service_driver.sh:
|
#!/bin/bash #这里的数据就可以写死了 mysql_username=root backup_databases=school backup_path=$HOME /backup_data/ ${backup_databases}.sql #运行expect脚本 expect $HOME /backup_script/single_cold_backup/single_cold_backup_service .exp ${mysql_username} ${backup_databases} ${backup_path} |
这里一定要十分注意自己的路径,强烈建议使用绝对路径来执行
(4)使用crontab周期执行驱动脚本
进入crontab编辑:crontab -e
输入如下内容:
|
0 9 * * 1 bash /home/hadoop/backup_script/single_cold_backup/single_cold_backup_driver .sh |
意思为:每周1早上9点执行一次备份
若你想确定自己想要的时间,可以到这个网址:https://crontab-generator.org/ 去点选自己想要的时间
3.2、双机冷备份
(1)复制远程文件,用于拷贝本地机的mysql备份文件
scp.sh:
|
#!/bin/bash local_backup_path=$1 another_user=$2 another_ip=$3 another_backup_path=$4 scp ${local_backup_path} ${another_user}@${another_ip}:${another_backup_path} |
(2)执行mysqldump的expect脚本,能帮助我们自动输入mysql代码
double_cold_backup_service.exp:
|
#!/usr/bin/expect set timeout 5 #主机信息 set mysql_username [lindex $argv 0] set backup_database [lindex $argv 1] set backup_path [lindex $argv 2] #从机信息 set slave_user [lindex $argv 3] set slave_ip [lindex $argv 4] set slave_backup_path [lindex $argv 5] #utils路径 set utils_path /home/hadoop/backup_script/utils spawn bash ${utils_path} /backup .sh ${mysql_username} ${backup_database} ${backup_path} expect { "*assword*" {send "nimabidecao1 " } #输入密码 } spawn bash ${utils_path} /scp .sh ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path} expect { "*assword*" {send "nimabidecao1 " } #输入密码 } expect eof |
(3)驱动脚本,执行expect,这里可以传入需要的参数
double_cold_backup_service_driver.sh:
|
#!/bin/bash #本机信息 mysql_username=root backup_databases=school backup_path=$HOME /backup_data/ ${backup_databases}.sql #从机信息 slave_user=meizhaowei slave_ip=172.20.10.14 slave_backup_path=backup_data /doule_cold_backup_data/ ${backup_databases}.sql #执行写绝对路径 expect $HOME /backup_script/double_cold_backup/double_cold_backup_service .exp ${mysql_username} ${backup_databases} ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path} |
(4)使用crontab周期执行驱动脚本
|
0 9 * * 1 bash /home/hadoop/backup_script/double_cold_backup/double_cold_backup_driver .sh |
意思是:每周1早上9点执行一次备份
到此这篇关于linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解的文章就介绍到这了,更多相关mysql周期冷备份内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://blog.csdn.net/lendsomething/article/details/109134810
- mysql插入数据错误代码(教你解决往mysql数据库中存入汉字报错的方法)
- mysql存储过程遍历数据(Mysql 存储过程中使用游标循环读取临时表)
- mysql查询条件的优化(MySQL查询优化之查询慢原因和解决技巧)
- mysql中定义字段时zerofill属性的作用
- mysql查看慢查询(MySQL 慢查询日志深入理解)
- mysql索引失效原因(MySQL索引失效的几种情况详析)
- navicat连接mysql是远程连接吗(详解Navicat远程连接mysql很慢)
- mysql 多表连接查询(MySQL多表查询的具体实例)
- 所有聚合函数mysql教程(Mysql 聚合函数嵌套使用操作)
- mysqldump 命令详解(mysqldump你可能不知道的参数)
- mysql详细笔记(MySQL的内存表的基础学习教程)
- navicat怎么和mysql连接(Navicat Premium远程连接MySQL数据库的方法)
- 关于mysql性能优化的描述(Mysql性能优化之索引下推)
- mysql创建数据库教程(MySQL创建数据库并支持中文字符的操作方法)
- mysql函数编写(MySQL中sum函数使用的实例教程)
- mysql时间戳和datetime对比(MySQL时间设置注意事项的深入总结)
- 七夕的寓意(七夕的寓意)
- 苏志燮赵恩静结婚,韩国四大公共财产变三人,这么快就有替补了(苏志燮赵恩静结婚)
- 《内在美》后,一大波新韩剧来袭,李钟硕朴信惠宋慧乔玄彬回归(一大波新韩剧来袭)
- 给孩子选购保温杯,注意这4个步骤,比颜值更重要(给孩子选购保温杯)
- 保温好 容量大 颜值高 保温杯你给娃娃买对了吗(保温好容量大颜值高)
- 《道德经》 人生避开骄狂,才能免去祸患(道德经人生避开骄狂)
热门推荐
- SQLServer将数据导出为SQL脚本
- pythonmath库引入方法(python使用thrift教程的方法示例)
- 宝塔面板怎么用ip访问站点(宝塔面板设置禁止通过IP直接访问网站防止恶意解析)
- dedecms数据库备份(dedecms网站搬家需要的备份的文件)
- mysql中date_format日期格式化
- tensorflow做识别分类(使用TensorFlow实现二分类的方法示例)
- python带权限复制文件夹(python定时复制远程文件夹中所有文件)
- php把当前网页生成pdf(php转换上传word文件为PDF的方法基于COM组件)
- js RegExp用法
- css怎么设置图片横着(一行css代码解决图片统一大小后的拉伸问题object-fit)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9