ubuntu

Ubuntu SFTP如何支持多用户

小樊
37
2025-07-28 09:25:59
栏目: 智能运维

在Ubuntu上配置SFTP多用户管理涉及几个关键步骤,包括安装OpenSSH服务器、创建用户和用户组、配置SSH以限制SFTP用户的访问、以及设置目录和权限。以下是详细的步骤:

安装OpenSSH服务器

首先,确保你的Ubuntu系统上已经安装了OpenSSH服务器。如果没有安装,可以使用以下命令进行安装:

sudo apt update
sudo apt install openssh-server

创建SFTP用户和组

  1. 创建一个新的用户组(例如 sftp_users),用于管理SFTP用户:
sudo groupadd sftp_users
  1. 创建一个新的SFTP用户(例如 sftpuser),并将其添加到新创建的组。同时设置该用户的密码:
sudo useradd -m sftpuser -g sftp_users
sudo passwd sftpuser

配置OpenSSH以限制SFTP用户的访问

编辑 /etc/ssh/sshd_config 文件以限制SFTP用户对其根目录的访问:

sudo nano /etc/ssh/sshd_config

在文件末尾添加以下内容:

Match Group sftp_users
    ChrootDirectory /sftp_root
    ForceCommand internal-sftp
    AllowTcpForwarding no
    X11Forwarding no

这里,/sftp_root 是SFTP用户的根目录,你需要根据实际情况进行更改。

保存文件并退出编辑器。

设置用户目录和权限

  1. 创建一个新目录,用作SFTP用户的根目录(例如 /sftp_root):
sudo mkdir /sftp_root
  1. 为新创建的SFTP用户创建一个子目录,作为其个人目录:
sudo mkdir /sftp_root/sftpuser
  1. 更改SFTP根目录和个人目录的所有者和权限:
sudo chown root:root /sftp_root
sudo chmod 755 /sftp_root
sudo chown sftpuser:sftp_users /sftp_root/sftpuser
sudo chmod 700 /sftp_root/sftpuser

测试SFTP连接

使用刚刚创建的SFTP用户名和密码进行登录,以测试配置是否正确:

sftp sftpuser@your_server_ip

通过以上步骤,你可以在Ubuntu上成功配置SFTP多用户管理,确保每个用户只能访问其指定的目录,从而提高系统的安全性。

0
看了该问题的人还看了