mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
Translated
This commit is contained in:
parent
ae732b5c1b
commit
80ae229a5a
@ -1,197 +0,0 @@
|
|||||||
[#]: collector: (lujun9972)
|
|
||||||
[#]: translator: (robsean)
|
|
||||||
[#]: reviewer: ( )
|
|
||||||
[#]: publisher: ( )
|
|
||||||
[#]: url: ( )
|
|
||||||
[#]: subject: (How to Configure SFTP Server with Chroot in Debian 10)
|
|
||||||
[#]: via: (https://www.linuxtechi.com/configure-sftp-chroot-debian10/)
|
|
||||||
[#]: author: (Pradeep Kumar https://www.linuxtechi.com/author/pradeep/)
|
|
||||||
|
|
||||||
How to Configure SFTP Server with Chroot in Debian 10
|
|
||||||
======
|
|
||||||
|
|
||||||
**SFTP** stands for Secure File Transfer Protocol / SSH File Transfer Protocol, it is one of the most common method which is used to transfer files securely over ssh from our local system to remote server and vice-versa. The main advantage of sftp is that we don’t need to install any additional package except ‘**openssh-server**’, in most of the Linux distributions ‘openssh-server’ package is the part of default installation. Other benefit of sftp is that we can allow user to use sftp only not ssh.
|
|
||||||
|
|
||||||
[![Configure-sftp-debian10][1]][2]
|
|
||||||
|
|
||||||
Recently Debian 10, Code name ‘Buster’ has been released, in this article we will demonstrate how to configure sftp with Chroot ‘Jail’ like environment in Debian 10 System. Here Chroot Jail like environment means that user’s cannot go beyond from their respective home directories or users cannot change directories from their home directories. Following are the lab details:
|
|
||||||
|
|
||||||
* OS = Debian 10
|
|
||||||
* IP Address = 192.168.56.151
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Let’s jump into SFTP Configuration Steps,
|
|
||||||
|
|
||||||
### Step:1) Create a Group for sftp using groupadd command
|
|
||||||
|
|
||||||
Open the terminal, create a group with a name “**sftp_users**” using below groupadd command,
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# groupadd sftp_users
|
|
||||||
```
|
|
||||||
|
|
||||||
### Step:2) Add Users to Group ‘sftp_users’ and set permissions
|
|
||||||
|
|
||||||
In case you want to create new user and want to add that user to ‘sftp_users’ group, then run the following command,
|
|
||||||
|
|
||||||
**Syntax:** # useradd -m -G sftp_users <user_name>
|
|
||||||
|
|
||||||
Let’s suppose user name is ’Jonathan’
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# useradd -m -G sftp_users jonathan
|
|
||||||
```
|
|
||||||
|
|
||||||
set the password using following chpasswd command,
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# echo "jonathan:<enter_password>" | chpasswd
|
|
||||||
```
|
|
||||||
|
|
||||||
In case you want to add existing users to ‘sftp_users’ group then run beneath usermod command, let’s suppose already existing user name is ‘chris’
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# usermod -G sftp_users chris
|
|
||||||
```
|
|
||||||
|
|
||||||
Now set the required permissions on Users,
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# chown root /home/jonathan /home/chris/
|
|
||||||
```
|
|
||||||
|
|
||||||
Create an upload folder in both the user’s home directory and set the correct ownership,
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# mkdir /home/jonathan/upload
|
|
||||||
root@linuxtechi:~# mkdir /home/chris/upload
|
|
||||||
root@linuxtechi:~# chown jonathan /home/jonathan/upload
|
|
||||||
root@linuxtechi:~# chown chris /home/chris/upload
|
|
||||||
```
|
|
||||||
|
|
||||||
**Note:** User like Jonathan and Chris can upload files and directories to upload folder from their local systems.
|
|
||||||
|
|
||||||
### Step:3) Edit sftp configuration file (/etc/ssh/sshd_config)
|
|
||||||
|
|
||||||
As we have already stated that sftp operations are done over the ssh, so it’s configuration file is “**/etc/ssh/sshd_config**“, Before making any changes I would suggest first take the backup and then edit this file and add the following content,
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# cp /etc/ssh/sshd_config /etc/ssh/sshd_config-org
|
|
||||||
root@linuxtechi:~# vim /etc/ssh/sshd_config
|
|
||||||
………
|
|
||||||
#Subsystem sftp /usr/lib/openssh/sftp-server
|
|
||||||
Subsystem sftp internal-sftp
|
|
||||||
|
|
||||||
Match Group sftp_users
|
|
||||||
X11Forwarding no
|
|
||||||
AllowTcpForwarding no
|
|
||||||
ChrootDirectory %h
|
|
||||||
ForceCommand internal-sftp
|
|
||||||
…………
|
|
||||||
```
|
|
||||||
|
|
||||||
Save & exit the file.
|
|
||||||
|
|
||||||
To make above changes into the affect, restart ssh service using following systemctl command
|
|
||||||
|
|
||||||
```
|
|
||||||
root@linuxtechi:~# systemctl restart sshd
|
|
||||||
```
|
|
||||||
|
|
||||||
In above ‘sshd_config’ file we have commented out the line which starts with “Subsystem” and added new entry “Subsystem sftp internal-sftp” and new lines like,
|
|
||||||
|
|
||||||
“**Match Group sftp_users”** –> It means if a user is a part of ‘sftp_users’ group then apply rules which are mentioned below to this entry.
|
|
||||||
|
|
||||||
“**ChrootDierctory %h**” –> It means users can only change directories within their respective home directories, they cannot go beyond their home directories, or in other words we can say users are not permitted to change directories, they will get jai like environment within their directories and can’t access any other user’s and system’s directories.
|
|
||||||
|
|
||||||
“**ForceCommand internal-sftp**” –> It means users are limited to sftp command only.
|
|
||||||
|
|
||||||
### Step:4) Test and Verify sftp
|
|
||||||
|
|
||||||
Login to any other Linux system which is on the same network of your sftp server and then try to ssh sftp server via the users that we have mapped in ‘sftp_users’ group.
|
|
||||||
|
|
||||||
```
|
|
||||||
[root@linuxtechi ~]# ssh root@linuxtechi
|
|
||||||
root@linuxtechi's password:
|
|
||||||
Write failed: Broken pipe
|
|
||||||
[root@linuxtechi ~]# ssh root@linuxtechi
|
|
||||||
root@linuxtechi's password:
|
|
||||||
Write failed: Broken pipe
|
|
||||||
[root@linuxtechi ~]#
|
|
||||||
```
|
|
||||||
|
|
||||||
Above confirms that users are not allowed to SSH , now try sftp using following commands,
|
|
||||||
|
|
||||||
```
|
|
||||||
[root@linuxtechi ~]# sftp root@linuxtechi
|
|
||||||
root@linuxtechi's password:
|
|
||||||
Connected to 192.168.56.151.
|
|
||||||
sftp> ls -l
|
|
||||||
drwxr-xr-x 2 root 1001 4096 Sep 14 07:52 debian10-pkgs
|
|
||||||
-rw-r--r-- 1 root 1001 155 Sep 14 07:52 devops-actions.txt
|
|
||||||
drwxr-xr-x 2 1001 1002 4096 Sep 14 08:29 upload
|
|
||||||
```
|
|
||||||
|
|
||||||
Let’s try to download a file using sftp ‘**get**‘ command
|
|
||||||
|
|
||||||
```
|
|
||||||
sftp> get devops-actions.txt
|
|
||||||
Fetching /devops-actions.txt to devops-actions.txt
|
|
||||||
/devops-actions.txt 100% 155 0.2KB/s 00:00
|
|
||||||
sftp>
|
|
||||||
sftp> cd /etc
|
|
||||||
Couldn't stat remote file: No such file or directory
|
|
||||||
sftp> cd /root
|
|
||||||
Couldn't stat remote file: No such file or directory
|
|
||||||
sftp>
|
|
||||||
```
|
|
||||||
|
|
||||||
Above output confirms that we are able to download file from our sftp server to local machine and apart from this we have also tested that users cannot change directories.
|
|
||||||
|
|
||||||
Let’s try to upload a file under “**upload**” folder,
|
|
||||||
|
|
||||||
```
|
|
||||||
sftp> cd upload/
|
|
||||||
sftp> put metricbeat-7.3.1-amd64.deb
|
|
||||||
Uploading metricbeat-7.3.1-amd64.deb to /upload/metricbeat-7.3.1-amd64.deb
|
|
||||||
metricbeat-7.3.1-amd64.deb 100% 38MB 38.4MB/s 00:01
|
|
||||||
sftp> ls -l
|
|
||||||
-rw-r--r-- 1 1001 1002 40275654 Sep 14 09:18 metricbeat-7.3.1-amd64.deb
|
|
||||||
sftp>
|
|
||||||
```
|
|
||||||
|
|
||||||
This confirms that we have successfully uploaded a file from our local system to sftp server.
|
|
||||||
|
|
||||||
Now test the SFTP server with winscp tool, enter the sftp server ip address along user’s credentials,
|
|
||||||
|
|
||||||
[![Winscp-sftp-debian10][1]][3]
|
|
||||||
|
|
||||||
Click on Login and then try to download and upload files
|
|
||||||
|
|
||||||
[![Download-file-winscp-debian10-sftp][1]][4]
|
|
||||||
|
|
||||||
Now try to upload files in upload folder,
|
|
||||||
|
|
||||||
[![Upload-File-using-winscp-Debian10-sftp][1]][5]
|
|
||||||
|
|
||||||
Above window confirms that uploading is also working fine, that’s all from this article. If these steps help you to configure SFTP server with chroot environment in Debian 10 then please do share your feedback and comments.
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
via: https://www.linuxtechi.com/configure-sftp-chroot-debian10/
|
|
||||||
|
|
||||||
作者:[Pradeep Kumar][a]
|
|
||||||
选题:[lujun9972][b]
|
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
||||||
|
|
||||||
[a]: https://www.linuxtechi.com/author/pradeep/
|
|
||||||
[b]: https://github.com/lujun9972
|
|
||||||
[1]: 
|
|
||||||
[2]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Configure-sftp-debian10.jpg
|
|
||||||
[3]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Winscp-sftp-debian10.jpg
|
|
||||||
[4]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Download-file-winscp-debian10-sftp.jpg
|
|
||||||
[5]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Upload-File-using-winscp-Debian10-sftp.jpg
|
|
@ -0,0 +1,197 @@
|
|||||||
|
[#]: collector: (lujun9972)
|
||||||
|
[#]: translator: (robsean)
|
||||||
|
[#]: reviewer: ( )
|
||||||
|
[#]: publisher: ( )
|
||||||
|
[#]: url: ( )
|
||||||
|
[#]: subject: (How to Configure SFTP Server with Chroot in Debian 10)
|
||||||
|
[#]: via: (https://www.linuxtechi.com/configure-sftp-chroot-debian10/)
|
||||||
|
[#]: author: (Pradeep Kumar https://www.linuxtechi.com/author/pradeep/)
|
||||||
|
|
||||||
|
如何在 Debian 10 中使用 Chroot 配置 SFTP 服务
|
||||||
|
======
|
||||||
|
|
||||||
|
**SFTP** 代表安全文件传输协议 / SSH 文件传输协议,它是最常用的一个方法,用于通过ssh将文件从本地系统安全地传输到远程服务器,反之亦然。sftp 的主要优点是,除 ‘**openssh-server**’ 之外,我们不需要安装任何额外的软件包,在大多数的 Linux 发行版中,‘openssh-server’ 软件包是默认安装的一部分。sftp 的另外一个好处是,我们可以允许用户使用 sftp ,而不允许使用 ssh 。
|
||||||
|
|
||||||
|
[![配置-sftp-debian10][1]][2]
|
||||||
|
|
||||||
|
当前 Debian 10 ,代号‘Buster’,已经发布,在这篇文章中,我们将演示如何在 Debian 10 系统中使用 Chroot ‘Jail’ 类似的环境配置 sftp 。在这里,Chroot Jail 类似环境意味着,用户不能超出各自的 home 目录,或者用户不能从各自的 home 目录更改目录。下面实验的详细情况:
|
||||||
|
|
||||||
|
* OS = Debian 10
|
||||||
|
* IP 地址 = 192.168.56.151
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
让我们跳转到 SFTP 配置步骤,
|
||||||
|
|
||||||
|
### 步骤:1) 为 sftp 使用 groupadd 命令创建一个组
|
||||||
|
|
||||||
|
打开终端,使用下面的 groupadd 命令创建一个名为的“**sftp_users**”组,
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# groupadd sftp_users
|
||||||
|
```
|
||||||
|
|
||||||
|
### 步骤:2) 添加用户到组 ‘sftp_users’ 并设置权限
|
||||||
|
|
||||||
|
假设你想创建新的用户,并且想添加该用户到 ‘sftp_users’ 组中,那么运行下面的命令,
|
||||||
|
|
||||||
|
**语法:** # useradd -m -G sftp_users <user_name>
|
||||||
|
|
||||||
|
让我们假设用户名是 ’Jonathan’
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# useradd -m -G sftp_users jonathan
|
||||||
|
```
|
||||||
|
|
||||||
|
使用下面的 chpasswd 命令设置密码,
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# echo "jonathan:<enter_password>" | chpasswd
|
||||||
|
```
|
||||||
|
|
||||||
|
假设你想添加现有的用户到 ‘sftp_users’ 组中,那么运行下面的 usermod 命令,让我们假设已经存在的用户名称是 ‘chris’
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# usermod -G sftp_users chris
|
||||||
|
```
|
||||||
|
|
||||||
|
现在设置用户所需的权限,
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# chown root /home/jonathan /home/chris/
|
||||||
|
```
|
||||||
|
|
||||||
|
在各用户的 home 目录中都创建一个上传目录,并设置正确地所有权,
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# mkdir /home/jonathan/upload
|
||||||
|
root@linuxtechi:~# mkdir /home/chris/upload
|
||||||
|
root@linuxtechi:~# chown jonathan /home/jonathan/upload
|
||||||
|
root@linuxtechi:~# chown chris /home/chris/upload
|
||||||
|
```
|
||||||
|
|
||||||
|
**注意:** 像 Jonathan 和 Chris 之类的用户可以从他们的本地系统上传文件和目录。
|
||||||
|
|
||||||
|
### 步骤:3) 编辑 sftp 配置文件 (/etc/ssh/sshd_config)
|
||||||
|
|
||||||
|
正如我们已经陈述的,sftp 操作是通过 ssh 完成的,所以它的配置文件是 “**/etc/ssh/sshd_config**“, 在做任何更改前,我建议首先备份文件,然后再编辑该文件,接下来添加下面的内容,
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# cp /etc/ssh/sshd_config /etc/ssh/sshd_config-org
|
||||||
|
root@linuxtechi:~# vim /etc/ssh/sshd_config
|
||||||
|
………
|
||||||
|
#Subsystem sftp /usr/lib/openssh/sftp-server
|
||||||
|
Subsystem sftp internal-sftp
|
||||||
|
|
||||||
|
Match Group sftp_users
|
||||||
|
X11Forwarding no
|
||||||
|
AllowTcpForwarding no
|
||||||
|
ChrootDirectory %h
|
||||||
|
ForceCommand internal-sftp
|
||||||
|
…………
|
||||||
|
```
|
||||||
|
|
||||||
|
保存并退出文件。
|
||||||
|
|
||||||
|
为使上述更改生效,使用下面的 systemctl 命令来重新启动 ssh 服务
|
||||||
|
|
||||||
|
```
|
||||||
|
root@linuxtechi:~# systemctl restart sshd
|
||||||
|
```
|
||||||
|
|
||||||
|
在上面的 ‘sshd_config’ 文件中,我们已经注释掉了以 “Subsystem”开头的行,并添加了新的条目 “Subsystem sftp internal-sftp” 和新的行,像,
|
||||||
|
|
||||||
|
“**Match Group sftp_users”** –> 它意味着如果用户是 ‘sftp_users’ 组中的一员,那么将应用下面提到的规则到这个条目。
|
||||||
|
|
||||||
|
“**ChrootDierctory %h**” –> 它意味着用户只能在他们自己各自的 home 目录中更改目录,而不能超出他们各自的 home 目录。或者换句话说,我们可以说用户是不允许更改目录的。他们将在他们的目录中获得 jai 类似环境,并且不能访问其他用户的目录和系统的目录。
|
||||||
|
|
||||||
|
“**ForceCommand internal-sftp**” –> 它意味着用户仅被限制到 sftp 命令。
|
||||||
|
|
||||||
|
### 步骤:4) 测试和验证 sftp
|
||||||
|
|
||||||
|
登录到你的 sftp 服务器的同一个网络上的任何其它的 Linux 系统,然后通过我们在 ‘sftp_users’ 组中映射的用户来尝试 ssh sftp 服务。
|
||||||
|
|
||||||
|
```
|
||||||
|
[root@linuxtechi ~]# ssh root@linuxtechi
|
||||||
|
root@linuxtechi's password:
|
||||||
|
Write failed: Broken pipe
|
||||||
|
[root@linuxtechi ~]# ssh root@linuxtechi
|
||||||
|
root@linuxtechi's password:
|
||||||
|
Write failed: Broken pipe
|
||||||
|
[root@linuxtechi ~]#
|
||||||
|
```
|
||||||
|
|
||||||
|
以上操作证实用户不允许 SSH ,现在使用下面的命令尝试 sftp ,
|
||||||
|
|
||||||
|
```
|
||||||
|
[root@linuxtechi ~]# sftp root@linuxtechi
|
||||||
|
root@linuxtechi's password:
|
||||||
|
Connected to 192.168.56.151.
|
||||||
|
sftp> ls -l
|
||||||
|
drwxr-xr-x 2 root 1001 4096 Sep 14 07:52 debian10-pkgs
|
||||||
|
-rw-r--r-- 1 root 1001 155 Sep 14 07:52 devops-actions.txt
|
||||||
|
drwxr-xr-x 2 1001 1002 4096 Sep 14 08:29 upload
|
||||||
|
```
|
||||||
|
|
||||||
|
让我们使用 sftp ‘**get**‘ 命令来尝试下载一个文件
|
||||||
|
|
||||||
|
```
|
||||||
|
sftp> get devops-actions.txt
|
||||||
|
Fetching /devops-actions.txt to devops-actions.txt
|
||||||
|
/devops-actions.txt 100% 155 0.2KB/s 00:00
|
||||||
|
sftp>
|
||||||
|
sftp> cd /etc
|
||||||
|
Couldn't stat remote file: No such file or directory
|
||||||
|
sftp> cd /root
|
||||||
|
Couldn't stat remote file: No such file or directory
|
||||||
|
sftp>
|
||||||
|
```
|
||||||
|
|
||||||
|
上面的输出证实我们能从我们的 sftp 服务器下载文件到本地机器,除此之外,我们也必需测试用户不能更改目录。
|
||||||
|
|
||||||
|
让我们在 **upload**”目录下尝试上传一个文件,
|
||||||
|
|
||||||
|
```
|
||||||
|
sftp> cd upload/
|
||||||
|
sftp> put metricbeat-7.3.1-amd64.deb
|
||||||
|
Uploading metricbeat-7.3.1-amd64.deb to /upload/metricbeat-7.3.1-amd64.deb
|
||||||
|
metricbeat-7.3.1-amd64.deb 100% 38MB 38.4MB/s 00:01
|
||||||
|
sftp> ls -l
|
||||||
|
-rw-r--r-- 1 1001 1002 40275654 Sep 14 09:18 metricbeat-7.3.1-amd64.deb
|
||||||
|
sftp>
|
||||||
|
```
|
||||||
|
|
||||||
|
这证实我们已经成功地从我们的本地系统上传一个文件到 sftp 服务中。
|
||||||
|
|
||||||
|
现在使用 winscp 工具来测试 SFTP 服务,输入 sftp 服务器 ip 地址和用户的凭证,
|
||||||
|
|
||||||
|
[![Winscp-sftp-debian10][1]][3]
|
||||||
|
|
||||||
|
在 Login 上单击,然后尝试下载和上传文件
|
||||||
|
|
||||||
|
[![下载-文件-winscp-debian10-sftp][1]][4]
|
||||||
|
|
||||||
|
现在,在 upload 文件夹中尝试上传文件,
|
||||||
|
|
||||||
|
[![使用-winscp-Debian10-sftp-上传-文件][1]][5]
|
||||||
|
|
||||||
|
上面的窗口证实上传是完好地工作的,这就是这篇文章的全部。如果这些步骤能帮助你在 Debian 10 中使用 chroot 环境配置 SFTP 服务器s,那么请分享你的反馈和评论。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://www.linuxtechi.com/configure-sftp-chroot-debian10/
|
||||||
|
|
||||||
|
作者:[Pradeep Kumar][a]
|
||||||
|
选题:[lujun9972][b]
|
||||||
|
译者:[robsean](https://github.com/robsean)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]: https://www.linuxtechi.com/author/pradeep/
|
||||||
|
[b]: https://github.com/lujun9972
|
||||||
|
[1]: 
|
||||||
|
[2]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Configure-sftp-debian10.jpg
|
||||||
|
[3]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Winscp-sftp-debian10.jpg
|
||||||
|
[4]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Download-file-winscp-debian10-sftp.jpg
|
||||||
|
[5]: https://www.linuxtechi.com/wp-content/uploads/2019/09/Upload-File-using-winscp-Debian10-sftp.jpg
|
Loading…
Reference in New Issue
Block a user