Ubuntu创建SFTP用户

本文指导如何在Ubuntu环境中安装OpenSSH服务器,创建SFTP用户,分配权限,配置SSH服务器以实现用户间的权限隔离,确保每个用户只能在其指定目录内操作,且仅限读写权限。

需求描述:创建多个SFTP用户,用户权限隔离,每个用户都只能在自己的目录下操作

环境:Ubuntu

1、安装OpenSSH服务器(如果未安装)

sudo apt update
sudo apt install openssh-server

2、创建一个SFTP用户组

sudo groupadd sftpusers

3、创建SFTP用户并分配到用户组

        使用 useradd 命令创建新的SFTP用户,并使用 -G 选项将其添加到刚刚创建的用户组,限制其登录Shell为 /bin/false,确保用户的家目录位于 /sftp 目录下

sudo useradd -m -s /bin/false -G sftpusers sftpuser1
sudo passwd sftpuser1

4、创建SFTP根目录并设置权限

sudo mkdir /sftp/sftpuser1
sudo chown root:sftpusers /sftp/sftpuser1
sudo chmod 755 /sftp/sftpuser1

目录的权限设置有两个原则:

1、由ChrootDirectory指定的目录开始一直往上到系统根目录为止的目录拥有者都只能是root
2、由ChrootDirectory指定的目录开始一直往上到系统根目录为止都不可以具有群组写入权限

5、配置SSH服务器

        编辑SSH服务器的配置文件 /etc/ssh/sshd_config,并添加以下配置来强制SFTP用户组只能使用SFTP协议

Match Group sftpusers
ForceCommand internal-sftp
ChrootDirectory /sftp/%u
PermitRootLogin no
PasswordAuthentication yes

6、重启SSH服务器以应用更改

sudo service ssh restart

到这里用户sftpuser1可以使用SFTP协议登录,但用户只有读和执行权限,没有写的权限

下述操作可为sftpuser1创建单独的操作目录,为用户创建一个 home 目录,根据自己的需求添加权限

sudo chown sftpuser1:sftpusers /sftp/sftpuser1/home

设置所有者sftpuser1有写入权限,而所有组sftpusers无写入权限

sudo chmod 755 /sftp/sftpuser1/home

参考文档:

SFTP账号连接出现错误fatal: bad ownership or modes for chroot directory component “/“ [postauth]-优快云博客

Ubuntu系统中创建sftp用户,有以下两种常见方法: ### 方法一 1. 创建一个专门用于sftp用户用户组: ```bash groupadd sftpusers ``` 可通过`cat /etc/group |more`查看用户组信息。 2. 创建一个用户`test`,并将该用户的shell设置为`/bin/false`,使其没有登陆shell的权限,同时设置用户密码: ```bash useradd -s /bin/false -G sftpusers test passwd test # 输入密码,例如test123 ``` 3. 编辑`/etc/ssh/sshd_config`文件,找到`Subsystem`配置项,将其修改为`Subsystem sftp internal-sftp`。在文件最尾处增加配置,设定属于用户组`sftpusers`的用户都只能访问自己的文件夹: ```plaintext Match Group sftpusers X11Forwarding no AllowTcpForwarding no ForceCommand internal-sftp ChrootDirectory /var/sftp/ # 需在 /var/sftp/ 创建test和ledpc文件夹,该文件夹就是登录的sftp用户目录 ``` 保存并关闭文件。 4. 修改`test`用户所在文件夹的权限,让其属于`root`用户: ```bash chown root:root /var/sftp/test ``` 5. 重启`sshd`服务: ```bash service sshd restart sudo /etc/init.d/ssh restart ``` 6. 测试用户账号: ```bash ssh test@localhost ``` 若连接被拒绝,证明该用户没有ssh shell登录的权限 [^1]。 ### 方法二 在root用户登录下,使用`useradd`命令新增用户,设置用户组、不允许登录shell和家目录。示例如下: ```bash useradd -m sfuser -g sftp -s /sbin/nologin -d /data/sftp/sfuser ``` 此命令创建了一个名为`sfuser`的用户用户组为`sftp`,不允许登录shell,家目录为`/data/sftp/sfuser` [^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值