程序员

如何在Debian 10中配置Chroot环境的SFTP服务

作者:admin 2021-10-26 我要评论

SFTP 意思是 安全文件传输协议 Secure File Transfer Protocol 或 SSH 文件传输协议 SSH File Transfer Protocol ,它是最常用的用于通过 ssh 将文件从本地系统...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

如何在Debian 10中配置Chroot环境的SFTP服务

SFTP 意思是“安全文件传输协议Secure File Transfer Protocol” 或 “SSH 文件传输协议SSH File Transfer Protocol”,它是最常用的用于通过 ssh 将文件从本地系统安全地传输到远程服务器的方法,反之亦然。sftp 的主要优点是,除 openssh-server 之外,我们不需要安装任何额外的软件包,在大多数的 Linux 发行版中,openssh-server 软件包是默认安装的一部分。sftp 的另外一个好处是,我们可以允许用户使用 sftp ,而不允许使用 ssh

当前发布的 Debian 10 代号为 ‘Buster’,在这篇文章中,我们将演示如何在 Debian 10 系统中在 “监狱式的” Chroot 环境中配置 sftp。在这里,Chroot 监狱式环境意味着,用户不能超出各自的家目录,或者用户不能从各自的家目录更改目录。下面实验的详细情况:

  • OS = Debian 10
  • IP 地址 = 192.168.56.151

让我们跳转到 SFTP 配置步骤,

步骤 1、使用 groupadd 命令给 sftp 创建一个组

打开终端,使用下面的 groupadd 命令创建一个名为的 sftp_users 组:

  1. root@linuxtechi:~# groupadd sftp_users

步骤 2、添加用户到组 sftp_users 并设置权限

假设你想创建新的用户,并且想添加该用户到 sftp_users 组中,那么运行下面的命令,

语法:

  1. # useradd -m -G sftp_users <用户名>

让我们假设用户名是 jonathan

  1. root@linuxtechi:~# useradd -m -G sftp_users jonathan

使用下面的 chpasswd 命令设置密码:

  1. root@linuxtechi:~# echo "jonathan:<输入密码>" | chpasswd

假设你想添加现有的用户到 sftp_users 组中,那么运行下面的 usermod 命令,让我们假设已经存在的用户名称是 chris

  1. root@linuxtechi:~# usermod -G sftp_users chris

现在设置用户所需的权限:

  1. root@linuxtechi:~# chown root /home/jonathan /home/chris/

在各用户的家目录中都创建一个上传目录,并设置正确地所有权:

  1. root@linuxtechi:~# mkdir /home/jonathan/upload
  2. root@linuxtechi:~# mkdir /home/chris/upload
  3. root@linuxtechi:~# chown jonathan /home/jonathan/upload
  4. root@linuxtechi:~# chown chris /home/chris/upload

注意: 像 Jonathan 和 Chris 之类的用户可以从他们的本地系统上传文件和目录。

步骤 3、编辑 sftp 配置文件 /etc/ssh/sshd_config

正如我们已经陈述的,sftp 操作是通过 ssh 完成的,所以它的配置文件是 /etc/ssh/sshd_config,在做任何更改前,我建议首先备份文件,然后再编辑该文件,接下来添加下面的内容:

  1. root@linuxtechi:~# cp /etc/ssh/sshd_config /etc/ssh/sshd_config-org
  2. root@linuxtechi:~# vim /etc/ssh/sshd_config
  3. ......
  4. #Subsystem sftp /usr/lib/openssh/sftp-server
  5. Subsystem sftp internal-sftp
  6.  
  7. Match Group sftp_users
  8. X11Forwarding no
  9. AllowTcpForwarding no
  10. ChrootDirectory %h
  11. ForceCommand internal-sftp
  12. ......

保存并退出文件。

为使上述更改生效,使用下面的 systemctl 命令来重新启动 ssh 服务:

  1. root@linuxtechi:~# systemctl restart sshd

在上面的 sshd_config 文件中,我们已经注释掉了以 Subsystem 开头的行,并添加了新的条目 Subsystem sftp internal-sftp 和新的行。而

Match Group sftp_users –> 它意味着如果用户是 sftp_users 组中的一员,那么将应用下面提到的规则到这个条目。

ChrootDierctory %h –> 它意味着用户只能在他们自己各自的家目录中更改目录,而不能超出他们各自的家目录。或者换句话说,我们可以说用户是不允许更改目录的。他们将在他们的目录中获得监狱一样的环境,并且不能访问其他用户的目录和系统的目录。

ForceCommand internal-sftp –> 它意味着用户仅被限制到只能使用 sftp 命令。

步骤 4、测试和验证 sftp

登录到你的 sftp 服务器的同一个网络上的任何其它的 Linux 系统,然后通过我们放入 sftp_users 组中的用户来尝试 ssh 和 sftp 服务。

  1. [root@linuxtechi ~]# ssh root@linuxtechi
  2. root@linuxtechi's password:
  3. Write failed: Broken pipe
  4. [root@linuxtechi ~]# ssh root@linuxtechi
  5. root@linuxtechi's password:
  6. Write failed: Broken pipe
  7. [root@linuxtechi ~]#

以上操作证实用户不允许 ssh ,现在使用下面的命令尝试 sftp

  1. [root@linuxtechi ~]# sftp root@linuxtechi
  2. root@linuxtechi's password:
  3. Connected to 192.168.56.151.
  4. sftp> ls -l
  5. drwxr-xr-x 2 root 1001 4096 Sep 14 07:52 debian10-pkgs
  6. -rw-r--r-- 1 root 1001 155 Sep 14 07:52 devops-actions.txt
  7. drwxr-xr-x 2 1001 1002 4096 Sep 14 08:29 upload

让我们使用 sftp 的 get 命令来尝试下载一个文件:

  1. sftp> get devops-actions.txt
  2. Fetching /devops-actions.txt to devops-actions.txt
  3. /devops-actions.txt 100% 155 0.2KB/s 00:00
  4. sftp>
  5. sftp> cd /etc
  6. Couldn't stat remote file: No such file or directory
  7. sftp> cd /root
  8. Couldn't stat remote file: No such file or directory
  9. sftp>

上面的输出证实我们能从我们的 sftp 服务器下载文件到本地机器,除此之外,我们也必须测试用户不能更改目录。

让我们在 upload 目录下尝试上传一个文件:

  1. sftp> cd upload/
  2. sftp> put metricbeat-7.3.1-amd64.deb
  3. Uploading metricbeat-7.3.1-amd64.deb to /upload/metricbeat-7.3.1-amd64.deb
  4. metricbeat-7.3.1-amd64.deb 100% 38MB 38.4MB/s 00:01
  5. sftp> ls -l
  6. -rw-r--r-- 1 1001 1002 40275654 Sep 14 09:18 metricbeat-7.3.1-amd64.deb
  7. sftp>

这证实我们已经成功地从我们的本地系统上传一个文件到 sftp 服务中。

现在使用 winscp 工具来测试 sftp 服务,输入 sftp 服务器 IP 地址和用户的凭证:

在 “Login” 上单击,然后尝试下载和上传文件:

现在,在 upload 文件夹中尝试上传文件:

上面的窗口证实上传是完好地工作的,这就是这篇文章的全部。


本文转载自网络,原文链接:https://linux.cn/article-12186-1.html

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 如何在Debian 10中配置Chroot环境的SFT

    如何在Debian 10中配置Chroot环境的SFT

  • Windows 10夜间模式有Bug!教你如何解

    Windows 10夜间模式有Bug!教你如何解

  • 开发浏览器内核难吗?听说光代码就得几

    开发浏览器内核难吗?听说光代码就得几

  • 聊聊Ubuntu,聊聊开源,聊聊世界

    聊聊Ubuntu,聊聊开源,聊聊世界

腾讯云代理商
海外云服务器