一、遇到的问题
我们使用过mysqldump都知道,使用该命令后,需要我们手动输入 mysql的密码,那么我们就不能够直接在crontab中使用mysqldump实现周期备份。其实我们可以使用expect脚本自动输入密码,从而实现真正的周期备份。如果你不知道什么是expect,建议先请看这篇文章:https://www.jb51.net/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点执行一次备份
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 群星《歌手2024 第4期》[FLAC/分轨][563.76MB]
- RiffKitten-ChaosParade(2024)[24-44,1]FLAC
- RuneKlakegg-Nattevandrer(2024)[24-96]\FLAC
- 赖冰霞.2006-金嗓典藏辑2IN1(南方金点系列)2CD【南方】【WAV+CUE】
- 群星.1988-国语金曲尽精英VOL.2【瑞成】【WAV+CUE】
- 张宇.1999-雨一直下【EMI百代】【WAV+CUE】
- 袁娅维.2021-月亮失眠了(DELUXE)【华纳】【FLAC分轨】
- AlanBroadbent-JazzFunk(2024)[24-44,1]
- 梅艳芳《绝代芳华》开盘母带[低速原抓WAV+CUE]
- ABC唱片-《外国精逊母带直刻神奇黑胶[APE+CUE].
- 群星《天赐的声音第五季 第6期》[320K/MP3][101.43MB]
- 群星《天赐的声音第五季 第6期》[FLAC/分轨][526.16MB]
- 群星《说唱梦工厂 第2期》[320K/MP3][96.37MB]
- 杨宗宪.1994-留你留袂着【有容唱片】【WAV+CUE】
- 李翊君.2005-勇敢的爱【创意唱片】【WAV+CUE】