CentOS搭建SFTP

该文详细描述了如何创建并配置一个SFTP服务器,包括创建sftp用户组和用户,设置home目录,修改sshd_config以实现chroot隔离,并处理SELINUX权限和目录权限问题。在配置完成后,由于/data/目录权限不正确导致连接重置,通过日志排查并修正权限解决了问题。
摘要由CSDN通过智能技术生成

1、创建sftp组 :

 groupadd sftp

2、创建一个sftp用户,用户名为sftpu1 :

  useradd -g sftp -s /bin/false sftpu1

3、修改密码:  

passwd sftpu1

4、sftp组的用户的home目录统一指定到/sftp下:

mkdir -p /sftp/sftpu1

5、指定sftpu1的home为/sftp/sftpu1:

usermod -d /sftp/sftpu1 sftpu1

6、配置sshd_config:  

vi /etc/ssh/sshd_config

输入/Subsystem搜索到下列内容,然后注释:    
# Subsystem sftp /usr/libexec/openssh/sftp-server

在文件结尾处添加下面后保存:
 

Subsystem sftp internal-sftp
Match Group sftp
ChrootDirectory /sftp/%u
ForceCommand internal-sftp
AllowTcpForwarding no
X11Forwarding no

7、设定Chroot目录权限:

chown root:sftp /sftp/sftpu1
chmod 755 /sftp/sftpu1

8、建立SFTP用户登入后可写入的目录:

mkdir /sftp/sftpu1/upload
chown sftpu1:sftp /sftp/sftpu1/upload  
chmod 755 /sftp/sftpu1/upload

9、修改:

vim /etc/selinux/config
#SELINUX=enforcing
#改为
#SELINUX=disabled

10、输入命令:  

setenforce 0

11、重启sshd服务:

 service sshd restart

12、ifcong查询ip,进行登录:

sftp sftpu1@localhost

 

Connection reset by peer

都配置完之后, 就用sftp命令测试结果, 结果一测试, 就报

 
  1. Couldn't read packet:

  2. Connection reset by peer

解决方法

进入 /var/log/messages 日志 ,查看 secure文件,发现 /data/ 权限不对,授予root,sftp组权限即可,以此类推

Jul 12 17:25:33 localhost sshd[29261]: Accepted password for sftpuser from 127.0.0.1 port 59448 ssh2
Jul 12 17:25:33 localhost sshd[29261]: pam_unix(sshd:session): session opened for user sftpuser by (uid=0)
Jul 12 17:25:33 localhost sshd[29266]: fatal: bad ownership or modes for chroot directory component "/data/"
Jul 12 17:25:33 localhost sshd[29261]: pam_unix(sshd:session): session closed for user sftpuser
 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值