linux 搭建sftp服务

本文详细介绍了如何在Linux系统中创建一个名为mysftp的用户,将其限制在/data/sftp/mysftp目录下,仅允许进行sftp文件传输。步骤包括创建sftp组和用户,设置用户主目录,编辑sshd_config配置文件,限制用户权限,以及验证登录和文件上传功能。确保用户只能访问指定目录,不能切换到其他目录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考链接:https://www.cnblogs.com/reachos/p/11157329.html

以下为记录原文和遇到的问题

1.  创建sftp组

    groupadd sftp  

创建完成之后使用cat /etc/group命令组的信息

2. 创建一个sftp用户mysftp并加入到创建的sftp组中,同时修改mysftp用户的密码 

    useradd -g sftp -s /bin/false mysftp  

 passwd mysftp

创建完成后使用cat /etc/passwd查看用户信息

3. 新建/data/sftp/mysftp目录,并将它指定为mysftp组用户的home目录

 mkdir -p /data/sftp/mysftp  

 usermod -d /data/sftp/mysftp mysftp

4. 编辑配置文件/etc/ssh/sshd_config,vi /etc/ssh/sshd_config

  将如下这行用#符号注释掉

  # Subsystem      sftp    /usr/libexec/openssh/sftp-server  

     并在文件最后面添加如下几行内容然后保存

  Subsystem       sftp    internal-sftp    

  Match Group sftp    

  ChrootDirectory /data/sftp  

  ForceCommand    internal-sftp    问题

  AllowTcpForwarding no    暂无影响登录问题

  X11Forwarding no   

5. 设置Chroot目录权限

  chown root:sftp /data/sftp/mysftp 

  chmod 755 /data/sftp/mysftp

6. 新建一个目录供stp用户mysftp上传文件,这个目录所有者为mysftp所有组为sftp,所有者有写入权限所有组无写入权限

  mkdir /data/sftp/mysftp/upload  

  chown mysftp:sftp /data/sftp/mysftp/upload  

  chmod 755 /data/sftp/mysftp/upload  

7. 关闭selinux并重启sshd服务,然后测试

 systemctl restart sshd.service

8. 在其他服务器上进行验证,sftp 用户名@ip地址

    sftp mysftp@10.0.0.7

以上配置正常后,使用mysftp用户登录后只能查看/data/sftp的子目录文件,不能切换到/data/sftp目录和以上的其他目录中

使用xftp登录

使用sftp命令登录

问题1:配置错误的话会出现使用sftp命令登录失败问题,检查指定的目录所属用户和所属组,还有权限为755

问题2:当缺少Match Group sftp  会出现使用ssh命令无法登录问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值