写一个 Linux 自动备份脚本,把 A 服务器上的 /root/docker 文件夹的内容压缩之后每天早上 4 点 30 分自动备份到 B 服务器上的 /root/backup 目录下,要求最多保留 3 份备份。

其中 B 服务器的 SSH 端口为 2222,B 服务器上的 /root/backup 目录已经创建好了。

以下是一个可以完成所需任务的 bash 脚本。请将以下脚本保存为 backup.sh。

#!/bin/bash

# 服务器A上的源目录
SRC_DIR="/root/docker"

# 服务器B上的目标目录
DST_DIR="/root/backup"

# 服务器B的IP地址
SERVER_B_IP="your_server_b_ip"

# 服务器B的SSH用户名
SSH_USER="your_ssh_username"

# 服务器B的SSH端口
SSH_PORT="2222"

# 备份文件前缀
BACKUP_NAME_PREFIX="docker_backup"

# 压缩文件格式
ARCHIVE_FORMAT="tar.gz"

# 生成备份文件名
current_date=$(date +"%Y%m%d_%H%M%S")
backup_filename="${BACKUP_NAME_PREFIX}_${current_date}.${ARCHIVE_FORMAT}"

# 压缩源目录
tar -czf "${backup_filename}" -C "${SRC_DIR}" .

# 传输备份文件到服务器B
scp -P "${SSH_PORT}" "${backup_filename}" "${SSH_USER}@${SERVER_B_IP}:${DST_DIR}"

# 删除本地备份文件
rm -f "${backup_filename}"

# 保留最多3个备份文件
ssh -p "${SSH_PORT}" "${SSH_USER}@${SERVER_B_IP}" "ls -t ${DST_DIR}/${BACKUP_NAME_PREFIX}* | tail -n +4 | xargs --no-run-if-empty rm -f"

接下来,我们需要在服务器 A 上配置 cron job 以实现每天早上 4 点 30 分自动执行上面的备份脚本。请按照以下步骤操作:

使用 chmod 命令为脚本添加可执行权限:

chmod +x backup.sh

接下来,我们需要在 A 服务器上安装并配置 SSH 免密登录到 B 服务器。请在 A 服务器上执行以下命令:

# 安装sshpass(如已安装,请忽略)
sudo apt-get install sshpass

# 生成SSH密钥
ssh-keygen -t rsa -b 4096

# 一路回车即可


# 将公钥复制到B服务器
ssh-copy-id -i ~/.ssh/id_rsa.pub -p 服务器端口 user@B服务器IP地址

可以检测一下,A 服务器直接用 ssh -p 服务器端口 user@B服务器IP地址是否可以免密登录 B 服务器,如果可以,说明可以继续下一步。

  1. 使用 crontab -e 命令打开服务器 A 上的 cron 配置:
crontab -e

在打开的 cron 配置文件中,添加以下一行内容以设置每天早上 4 点 30 分执行 backup.sh 脚本。请确保将 /path/to/backup.sh 替换为实际的脚本文件路径。

30 4 * * * /root/backup.sh

保存并关闭 cron 配置文件。
现在,每天早上 4 点 30 分,脚本将自动执行,并将 /root/docker 目录压缩备份到服务器 B 的 /root/backup 目录下,同时保留最多 3 份备份。

若权限太高
执行

chmod 600 ~/.ssh/id_rsa