服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Linux通过ssh或ftp每天定时跨服务器备份文件

Linux通过ssh或ftp每天定时跨服务器备份文件

2023-12-18 17:09未知服务器之家 Linux

在数字化时代,数据已成为我们生活中不可或缺的一部分。然而,数据丢失或损坏的风险也随之增加。为了避免这种风险,我们需要构建一个安全、智能的自动化备份系统。本文将以SSH(安全外壳协议)和FTP(文件传输协议)为例

在数字化时代,数据已成为我们生活中不可或缺的一部分。然而,数据丢失或损坏的风险也随之增加。为了避免这种风险,我们需要构建一个安全、智能的自动化备份系统。本文将以SSH(安全外壳协议)和FTP(文件传输协议)为例,通过Linux系统的shell脚本定时执行,实现每天跨服务器自动备份的操作流程。

Linux通过ssh或ftp每天定时跨服务器备份文件

准备工作

1. 生成SSH密钥对

在本地机器上执行以下命令生成SSH密钥对:

ssh-keygen -t rsa

按照提示操作,将生成的公钥(通常是~/.ssh/id_rsa.pub)复制到远程服务器上。在远程服务器上,将公钥添加到~/.ssh/authorized_keys文件中。

2. 安装所需的软件包

sudo apt-get update  
sudo apt-get install openssh-client lftp

创建执行脚本

1. 创建一个名为backup.sh的shell脚本,添加以下内容:

#!/bin/bash  


# 定义本地和远程服务器的相关参数  
LOCAL_DIR="/path/to/local/directory"  # 本地目录路径  
REMOTE_USER="your_remote_username"    # 远程服务器用户名  
REMOTE_HOST="your_remote_host"        # 远程服务器主机名或IP地址  
REMOTE_DIR="/path/to/remote/directory" # 远程服务器目录路径  
FTP_USER="your_ftp_username"          # FTP用户名  
FTP_PASSWORD="your_ftp_password"      # FTP密码  
FTP_HOST="your_ftp_host"              # FTP主机名或IP地址  
FTP_DIR="/path/to/ftp/directory"      # FTP目录路径  


# 通过SSH将文件传输到远程服务器  
rsync -avz --progress --delete $LOCAL_DIR $REMOTE_USER@$REMOTE_HOST:$REMOTE_DIR  


# 通过FTP将文件传输到备份服务器  
lftp -c "open -u $FTP_USER,$FTP_PASSWORD sftp://$FTP_HOST; put -r $LOCAL_DIR $FTP_DIR; exit"  


echo "Backup completed at $(date '+%Y-%m-%d %H:%M:%S')" >> /var/log/backup.log

使用时需要将脚本中的占位符(如/path/to/local/directory)替换为您的实际路径和凭据。此外,您可能需要根据您的需求修改选项(例如,rsync的-avz选项表示归档模式、递归和压缩传输)。

2. 为脚本添加执行权限:

chmod +x backup.sh

3. 配置cron作业以每天自动执行脚本:

执行以下命令以编辑crontab文件:

crontab -e

在文件的末尾添加以下行,以在每天的午夜执行脚本:

0 1 * * * /path/to/backup.sh >/dev/null 2>&1

保存并关闭文件。

至此,cron将在夜间自动执行备份脚本,简单的夸服务器备份操作已经可以实现了。

继续优化

上面步骤中创建的脚本和配置步骤看起来已经非常全面了,实际使用的过程中,这里有几点建议:

  1. 安全性:脚本中直接包含了FTP的用户名和密码,这样可能会存在安全问题。一种更安全的方式是使用.netrc文件来存储FTP的登录信息,或者在运行脚本时手动输入FTP密码。
  2. 错误处理:脚本中没有包含错误处理逻辑。如果rsync或lftp命令执行失败,脚本应该能够捕获错误,并将错误信息记录到日志文件中。
  3. 日志记录:脚本已经在完成后将一条消息记录到/var/log/backup.log,不过还是可以增加更详细的日志记录(同第2条),以便在出现问题时进行调试。
  4. 环境变量:为了提高脚本的灵活性和可维护性,可以考虑将一些参数(如本地和远程目录路径)设置为环境变量,而不是直接在脚本中硬编码。
  5. 注释:虽然脚本已经有了一些注释,但还可以添加更多注释来解释每个步骤的作用和目的,帮助其他人理解和维护脚本。
  6. 测试:在实际使用之前,需要在测试环境中充分测试脚本。

备份是非常重要的,因此务必确保备份脚本的可靠性和稳定性。

延伸 · 阅读

精彩推荐