Mysql备份数据库到另一台服务器

这是一个用于在Linux环境下自动备份MySQL数据库并保留最近5天备份的shell脚本。脚本首先通过mysqldump进行数据库备份,然后使用gzip进行压缩,接着通过scp将备份文件传输到另一台服务器,最后清理超过1天的旧备份。实现远程传输的免登录配置参考了指定链接。确保在Linux环境中执行此脚本时,文件类型为UNIX格式。
#!/bin/bash
echo ===============================执行时间 `date +%F-%H-%M-%S` starting
#!/bin/sh
# mysql_backup.sh: backup mysql databases and keep newest 5 days backup.
#
# Last updated: 2017Ū8Ղ8ɕ
# ----------------------------------------------------------------------
# This is a free shell script under GNU GPL version 2.0 or above
# Copyright (C) 翰翰
# mysql 数据备份
# ----------------------------------------------------------------------
# mysql安装目录/usr/local/mysql/
# mysql启动命令service mysqld start
# -----------------------------


#declare
MKDIR="/bin/mkdir"
RM="/bin/rm"
MV="/bin/mv"
GZIP="/bin/gzip"


#file path
db_user="root"
db_passwd="root@2019"
db_host="10.164.153.72"
# 备份目录
backup_dir="/data/pgm"
# 获取当前时间
time="$(date +"%Y-%m-%d-%H-%M")"
# mysql, mysqldump and some other bin's path
MYSQLDUMP="/usr/local/mysql/bin/mysqldump"
# check the directory for store backup is writeable
test ! -w $backup_dir && echo "Error: $backup_dir is un-writeable." && exit 0


# 备份的数据库名称
db="test"
$MYSQLDUMP -u $db_user -h $db_host -p$db_passwd $db | $GZIP -9 > "$backup_dir/$time.$db.gz"


#发送备份文件到另一台服务器
scp -r $backup_dir/$time.$db.gz chy@10.164.153.73:/data/mysql-back-up/
exit 0;

#发送完成之后删除数据库服务器中的文件
find /data/pgm/ -mtime +1 -name "*.gz" -exec rm -rf {} \;

echo ===============================执行时间 `date +%F-%H-%M-%S` ending

解压缩命令为:gunzip -c mysql.sql.gz

如何实现两台服务器的免登录,参考上一篇文章地址为:https://blog.youkuaiyun.com/pobasoft2012/article/details/116236981

如果是window下创建的sh文件,在linux系统下执行时会提示错误信息,需要修改文件类型doc为unix类型。

 

实现 MySQL 定时备份另一台服务器,可按以下方法操作: #### 1. 编写备份脚本 创建一个用于备份 MySQL 数据库并将备份文件传输到另一台服务器的脚本。以下是一个示例脚本: ```bash #!/bin/bash # 存放备份 sql 的地方 BACKUP=/www/scripts/backup # 数据库名称 DATABASE=energy # 后缀,用来区分备份文件 DATETIME=$(date +%Y-%m-%d-%H-%M) echo "备份文件存放于${BACKUP}/$DATABASE-$DATETIME.sql" # 导出 sql 文件到备份文件夹下,-u -p 分别输入自己的用户密码,11.11.11.11 代表本机的 ip mysqldump -h 11.11.11.11 -uroot -proot --all-databases > ${BACKUP}/$DATABASE-$DATETIME.sql echo "===导出成功,开始传输===" # 把生成的备份 sql 传到目标服务器里,22.22.22.22 代表目标的 ip scp ${BACKUP}/$DATABASE-$DATETIME.sql root@22.22.22.22:/data/mysqlAutoBackup echo "===数据库备份服务器成功===" ``` 上述脚本使用 `mysqldump` 命令备份数据库,并使用 `scp` 命令将备份文件传输到目标服务器。需要注意的是,`mysqldump` 的 `-h` 后面应写当前服务器IP,若为离线安装的 MySQL ,写 `localhost` 可能因没有 `mysqld.socket` 导致连接失败;`--all-databases` 表示备份全部数据库,若要指定多个数据库,需使用 `--databases` 并以空格隔开数据库名。`scp -P 22` 可指定 ssh 端口,不指定默认为 22 [^2][^3]。 #### 2. 配置免密登录(可选) 为避免每次传输文件时都输入密码,可将源服务器的公钥复制到目标服务器的 `/root/.ssh/authorized_keys` 文件中,之后就可以免密进行 `scp` 操作 [^4]。 #### 3. 设置定时任务 使用 `cron` 来设置定时任务,让备份脚本定期执行。首先赋予脚本执行权限: ```bash chmod 777 /path/to/your/backup_script.sh ``` 然后编辑 `cron` 表: ```bash crontab -e ``` 在打开的文件中添加定时任务,例如每天 00:02 执行备份脚本: ```plaintext 02 00 * * * sh /path/to/your/backup_script.sh ``` `cron` 表达式的语法可自行学习,这里设置为 00:02 是为了避免服务器在 0 点时有其他数据同步任务 [^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值