在CentOS上搭建SFTP服务器,通常需要使用OpenSSH软件包。以下是详细的步骤:
首先,确保你的CentOS系统是最新的,然后安装OpenSSH服务器。
sudo yum update -y
sudo yum install openssh-server -y
安装完成后,启动SSH服务并设置为开机自启。
sudo systemctl start sshd
sudo systemctl enable sshd
编辑SSH配置文件 /etc/ssh/sshd_config,以启用SFTP并对其进行配置。
sudo vi /etc/ssh/sshd_config
在文件中找到以下行并进行相应的修改:
确保以下行没有被注释掉(删除行首的 #):
Subsystem sftp /usr/libexec/openssh/sftp-server
可以添加或修改以下行来限制用户只能使用SFTP:
Match Group sftpusers
ChrootDirectory %h
ForceCommand internal-sftp
AllowTcpForwarding no
X11Forwarding no
创建一个新的用户组 sftpusers,并将需要使用SFTP的用户添加到该组。
sudo groupadd sftpusers
添加一个新用户并将其添加到 sftpusers 组。例如,添加用户 sftpuser:
sudo useradd -m -G sftpusers sftpuser
sudo passwd sftpuser
系统会提示你输入并确认新用户的密码。
为了安全起见,可以将用户的根目录设置为一个特定的目录,这样用户只能访问该目录及其子目录。
sudo chown root:root /home/sftpuser
sudo chmod 755 /home/sftpuser
然后创建一个子目录供用户使用:
sudo mkdir /home/sftpuser/upload
sudo chown sftpuser:sftpusers /home/sftpuser/upload
完成所有配置后,重启SSH服务以应用更改。
sudo systemctl restart sshd
现在,你可以使用SFTP客户端连接到服务器进行测试。例如,使用 sftp 命令:
sftp sftpuser@your_server_ip
输入密码后,你应该能够连接到服务器并访问 /home/sftpuser/upload 目录。
通过以上步骤,你就可以在CentOS上成功搭建一个SFTP服务器。