在CentOS上配置和使用SFTP的步骤如下:
首先,确保你的CentOS系统上已经安装了OpenSSH服务器。如果没有安装,可以使用以下命令进行安装:
sudo yum install openssh-server
安装完成后,启动SSH服务并设置为开机自启:
sudo systemctl start sshd
sudo systemctl enable sshd
创建一个新用户,专门用于SFTP访问。例如,创建一个名为sftpuser
的用户:
sudo useradd -m -s /sbin/nologin sftpuser
然后为该用户设置密码:
sudo passwd sftpuser
创建一个目录,用于存放SFTP用户的主目录:
sudo mkdir /home/sftpuser
设置该目录的权限:
sudo chown root:root /home/sftpuser
sudo chmod 755 /home/sftpuser
在该目录下创建用户可以写入的子目录:
sudo mkdir /home/sftpuser/data
sudo chown sftpuser:sftpuser /home/sftpuser/data
sudo chmod 755 /home/sftpuser/data
编辑SSH配置文件/etc/ssh/sshd_config
,确保以下配置已启用:
# 启用SFTP子系统
Subsystem sftp internal-sftp
# 限制用户访问的根目录
Match User sftpuser
ChrootDirectory /home/sftpuser
ForceCommand internal-sftp
AllowTcpForwarding no
X11Forwarding no
PasswordAuthentication yes
注意:将sftpuser
替换为你创建的用户名。
保存配置文件后,重启SSH服务以使更改生效:
sudo systemctl restart sshd
现在,你可以使用SFTP客户端(如FileZilla)以sftp://sftpuser@your_server_ip/
的格式连接到你的CentOS服务器,并使用新创建的用户名和密码进行身份验证,进行文件传输测试。