在Ubuntu上开启SFTP服务,通常需要使用OpenSSH服务器。以下是详细步骤:
首先,确保你的系统上已经安装了OpenSSH服务器。如果没有安装,可以使用以下命令进行安装:
sudo apt update
sudo apt install openssh-server
安装完成后,启动SSH服务并设置为开机自启动:
sudo systemctl start ssh
sudo systemctl enable ssh
默认情况下,OpenSSH服务器已经配置为允许SFTP。你可以通过编辑SSH配置文件来进一步自定义设置。
打开SSH配置文件:
sudo nano /etc/ssh/sshd_config
在文件中找到或添加以下行:
Subsystem sftp /usr/lib/openssh/sftp-server
确保以下行没有被注释掉(即没有#
符号):
Protocol 2
保存并关闭文件。
为了使配置生效,重启SSH服务:
sudo systemctl restart ssh
如果你的系统启用了防火墙(如UFW),确保允许SSH连接:
sudo ufw allow ssh
你可以使用SFTP客户端(如FileZilla、WinSCP等)连接到你的Ubuntu服务器。连接信息如下:
如果你希望限制某些用户只能使用SFTP而不能使用SSH shell,可以在sshd_config
文件中进行配置:
Match User <username>
ForceCommand internal-sftp
PasswordAuthentication yes
ChrootDirectory %h
AllowTcpForwarding no
X11Forwarding no
将<username>
替换为你希望限制的用户名。保存并关闭文件,然后重启SSH服务:
sudo systemctl restart ssh
确保用户的家目录存在并且权限正确:
sudo mkdir -p /home/<username>
sudo chown <username>:<username> /home/<username>
sudo chmod 755 /home/<username>
将<username>
替换为你希望配置的用户。
通过以上步骤,你应该能够在Ubuntu上成功开启并配置SFTP服务。