在 CentOS 上设置 SFTP 服务器并定期备份其数据可以通过以下步骤完成:
首先,确保你的 CentOS 系统上已经安装了 OpenSSH 服务器和 rsync 工具。如果没有安装,可以使用以下命令进行安装:
sudo yum install openssh-server rsync
编辑 OpenSSH 服务器的配置文件 /etc/ssh/sshd_config
,确保以下配置项已经设置或取消注释(如果需要):
PubkeyAuthentication yes
PasswordAuthentication no
然后重启 SSH 服务以应用更改:
sudo systemctl restart sshd
创建一个用于 SFTP 的用户,并为其分配必要的权限。例如,创建一个名为 sftpuser
的用户:
sudo useradd -m sftpuser
sudo passwd sftpuser
按照提示设置密码。
将 SFTP 用户的家目录设置为 /home/sftpuser
,并确保该目录及其内容的权限正确:
sudo chown sftpuser:sftpuser /home/sftpuser
sudo chmod 755 /home/sftpuser
安装 rsync 并配置它以定期备份 SFTP 服务器的数据。例如,你可以创建一个脚本来执行备份:
sudo nano /usr/local/bin/backup_sftp.sh
在脚本中添加以下内容:
#!/bin/bash
# 源目录和目标备份目录
SOURCE="/home/sftpuser"
BACKUP_DIR="/path/to/backup/directory"
# 使用 rsync 进行备份
rsync -avz --delete $SOURCE/ $BACKUP_DIR/
# 输出备份日志
echo "Backup completed on $(date)" >> /var/log/sftp_backup.log
确保脚本具有可执行权限:
sudo chmod +x /usr/local/bin/backup_sftp.sh
使用 cron
设置定时任务以定期运行备份脚本。例如,每天凌晨 2 点运行备份脚本:
sudo crontab -e
在编辑器中添加以下行:
0 2 * * * /usr/local/bin/backup_sftp.sh
保存并退出编辑器。
手动运行备份脚本以确保它按预期工作:
/usr/local/bin/backup_sftp.sh
检查备份目录 /path/to/backup/directory
以确认备份是否成功。
通过以上步骤,你可以在 CentOS 上设置一个 SFTP 服务器,并使用 rsync 定期备份其数据。