linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解
#代码知识 发布时间: 2026-01-12
目录
- 一、遇到的问题
- 二、思路
- 三、代码
一、遇到的问题
我们使用过mysqldump都知道,使用该命令后,需要我们手动输入 mysql的密码,那么我们就不能够直接在crontab中使用mysqldump实现周期备份。其实我们可以使用expect脚本自动输入密码,从而实现真正的周期备份。如果你不知道什么是expect,建议先请看这篇文章:https://www./article/197865.htm

二、思路
- 创建一个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\r"} #输入密码
}
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\r"} #输入密码
}
spawn bash ${utils_path}/scp.sh ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path}
expect {
"*assword*" {send "nimabidecao1\r"} #输入密码
}
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点执行一次备份
代码知识SEO上一篇 : 浅谈HBase在SpringBoot项目里的应用(含HBaseUtil工具类)
下一篇 : uniapp实现横向滚动选择日期
-
SEO外包最佳选择国内专业的白帽SEO机构,熟知搜索算法,各行业企业站优化策略!
SEO公司
-
可定制SEO优化套餐基于整站优化与品牌搜索展现,定制个性化营销推广方案!
SEO套餐
-
SEO入门教程多年积累SEO实战案例,从新手到专家,从入门到精通,海量的SEO学习资料!
SEO教程
-
SEO项目资源高质量SEO项目资源,稀缺性外链,优质文案代写,老域名提权,云主机相关配置折扣!
SEO资源
-
SEO快速建站快速搭建符合搜索引擎友好的企业网站,协助备案,域名选择,服务器配置等相关服务!
SEO建站
-
快速搜索引擎优化建议没有任何SEO机构,可以承诺搜索引擎排名的具体位置,如果有,那么请您多注意!专业的SEO机构,一般情况下只能确保目标关键词进入到首页或者前几页,如果您有相关问题,欢迎咨询!