【Linux 操作系统配置 SFTP】

Linux 操作系统配置 SFTP

 sftp采用的是ssh加密隧道,安装性方面较ftp强,而且依赖的是系统自带的ssh服务,不像ftp还需要额外的进行安装基于 ssh 的 sftp 服务相比 ftp 有更好的安全性(非明文帐号密码传输)和方便的权限管理(限制用户的活动目录)。

实现目的:

 1、设置 sftp 帐号,使用户只能 sftp 操作文件, 而不能 ssh 到服务器;
 2、限定用户的活动目录,使用户只能在指定的目录下活动,使用 sftp 的 ChrootDirectory 配置;

查看ssh版本

ssh -V

1、添加用户组 sftp

groupadd sftp

2、创建sftp用户

useradd -g sftp -s /bin/false baksftp

-s /bin/false:不允许shell登录。
-g sftp:加入sftp组

3、设置密码

passwd baksftp

4、限定活动目录

mkdir -p /data/sftp/baksftp

5、配置Chroot目录权限

# 注意:此目录如果用于后续的 chroot 的活动目录,目录所有者必须是 root
chown root:sftp /data/sftp/baksftp
chmod 755 /data/sftp/baksftp

chroot 可能带来的问题
 因为 chroot 会将会话的根目录切换至此,所以 ssh 登录很可能会提示 /bin/bash: No such file or directory 的错误,因为此会话的路径会为 [chroot]/bin/bash

6、指定为sftp组用户的home目录

usermod -d /data/sftp/baksftp baksftp

7、修改ssh配置文件

vi /etc/ssh/sshd_config
7.1 基本的ssh远程登录配置
# 开启验证
PasswordAuthentication yes
# 禁止空密码登录
PermitEmptyPasswords no
# 开启远程登录
PermitRootLogin yes

至此可以使用 ssh 远程登录服务器了。

7.2 配置 sftp
# 修改Subsystem配置,使用系统自带的 internal-sftp 服务即可满足需求
# Subsystem      sftp    /usr/libexec/openssh/sftp-server
Subsystem      sftp    internal-sftp

Subsystem 是说 ssh 的子模块;这里启用的即为 sftp 模块,使用系统自带的 internal-sftp 来提供此服务

配置到这即可以使用帐号ssh登录,也可以使用ftp客户端sftp登录。

如果希望用户只能使用sftp而不能ssh登录到服务器,而且要限定用户的活动目录,继续看下面的配置:

# 对登录用户的限制
Match Group sftp	# 匹配sftp组
ChrootDirectory /data/sftp/%u # 限制用户在自己家目录
ForceCommand    internal-sftp # 限制只能使用sftp协议登录(如果要放通ssh登录,注释即可)
AllowTcpForwarding no
X11Forwarding no

Match [User|Group] userName|groupName
 Match [User|Group] sftp 这里是对登录用户的权限限定配置 Match 会对匹配到的用户或用户组起作用且高于 ssh 的通项配置。
ChrootDirectory
 用户的可活动目录可以用 %h 标识用户家目录 %u 代表用户名,当 Match 匹配的用户登录后,会话的根目录会切换至此目录。这里要尤其注意两个问题:
 1、 chroot 路径上的所有目录,所有者必须是 root,权限最大为 0755,这一点必须要注意。所以如果以非 root 用户登录时,我们需要在 chroot 下新建一个登录用户有权限操作的目录。
 2、chroot 一旦设定,则相应的用户登录时会话的根目录 “/” 切换为此目录,如果你此时使用 ssh 而非 sftp 协议登录,则很有可能会被提示:/bin/bash: No such file or directory
 对于此时登录的用户,会话中的根目录 “/” 已经切换为设置的 chroot 目录,除非 chroot 就是系统的 “/” 目录,否则此时的 chroot/bin 下是不会有 bash 命令的,这就类似添加用户时设定的 -s /bin/false 参数,shell 的初始命令式 /bin/false 自然就无法远程 ssh 登录了。
ForceCommand
 强制用户登录会话时使用的初始命令。如果如上配置了此项,则 Match 到的用户只能使用 sftp 协议登录,而无法使用 ssh 登录,会被提示:This service allows sftp connections only.

8、新建上传目录

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

mkdir /data/sftp/baksftp/upload
chown baksftp:sftp /data/sftp/baksftp/upload
chmod 755 /data/sftp/baksftp/upload

9、重启sshd服务

# 关闭selinux
setenforce 0
# 重启sshd服务
systemctl restart sshd.service

10、登录sftp

sftp -P22 baksftp@IP
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Linux系统上安装sftp,你可以按照以下步骤进行操作: 1. 注释掉sshd_config文件中的Subsystem sftp行。这可以通过编辑sshd_config文件并在该行前面添加注释符号(#)来完成。 2. 使用以下命令创建一个新用户,并将其添加到sftp组中: ``` useradd -m -d /app/sftp/test -g sftp -s /sbin/nologin test ``` 3. 编辑sshd_config文件,添加以下配置: ``` # sftp Subsystem Subsystem sftp internal-sftp Match Group sftp ChrootDirectory /data/sftp/%u ForceCommand internal-sftp AllowTcpForwarding no X11Forwarding no ``` 这将配置sftp系统,将匹配sftp组的用户限制在其指定的根目录下,禁止TCP转发和X11转发。 4. 修改用户的根目录为ChrootDirectory中指定的目录,并将其所有权设置为root:sftp: ``` chown root:sftp /data/sftp/mysftp chmod 755 /data/sftp/mysftp ``` 这将确保用户的根目录属于root用户并具有适当的权限。 5. 创建一个可供用户写入的目录,并将其所有权设置为mysftp:sftp,设置适当的权限: ``` mkdir /data/sftp/mysftp/upload chown mysftp:sftp /data/sftp/mysftp/upload chmod 755 /data/sftp/mysftp/upload ``` 这将创建一个用于上传文件的目录,并为用户提供适当的写入权限。 6. 禁用Selinux策略,通过编辑/etc/selinux/config文件并将其设置为禁用状态来实现: ``` vim /etc/selinux/config ``` 保存并关闭文件后,重启系统以使更改生效。 通过按照以上步骤进行操作,您将能够在Linux系统上成功安装和配置sftp。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Linux安装sftp](https://blog.csdn.net/sy201707/article/details/125183073)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [linux 安装SFTP](https://blog.csdn.net/qq_23605089/article/details/127958398)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值