Linux下搭建SFTP服务器

Linux下搭建SFTP服务器

本文详细介绍了在Linux系统上部署安全文件传输协议(SFTP)服务器的全过程,旨在提供一个既安全又高效的文件共享与传输解决方案。SFTP基于SSH(安全壳层协议)提供文件传输服务,继承了SSH的安全特性,如数据加密、完整性验证和服务器认证等,确保数据在传输过程中的安全性。

1、创建sftp的用户组

groupadd sftpgroup     #新增用户组

2、创建sftp⽤户账号并指定用户组和拒绝⽤户登录

useradd -g sftpgroup -s /bin/flase sftpadmin    #创建用户并限制用户登录

passwd sftpadmin     #设置密码

3、创建⼀个⽂件夹作为sftp账户的home⽬录

mkdir -p /data/sftp/sftpadmin 	#创建sftp文件夹

usermod -d /data/sftp/sftpadmin/ sftpadmin 	#将⽂件夹设置为sftpadmin⽤户的家⽬录

4、修改linux服务器的sftp配置

 vim /etc/ssh/sshd_config
 注释其中的 
 #Subsystem sftp /usr/libexec/openssh/sftp-server

 #新增配置如下

 # sftp setting
  Subsystem sftp internal-sftp
  Match Group sftpgroup
  ChrootDirectory /data/sftp/%u
  ForceCommand internal-sftp
  AllowTcpForwarding no
  X11Forwarding no

5、修改sftpadmin账户的home⽂件夹让其属于root

chown root ~sftpadmin    #设置文件夹的所属权限

chmod 755 /data/sftp/sftpadmin/           #设置⽂件夹权限

6、创建⽤户⽤于存储⽤户上传的⽂件夹并授权给对应的sftpgroup组中的sftpadmin

mkdir /data/sftp/sftpadmin/upload    #创建上传文件夹

chown sftpadmin:sftpgroup /data/sftp/sftpadmin/upload/  #设置文件夹的所属权限

chmod 755 /data/sftp/sftpadmin/upload/  #修改文件夹的读写权限

7、关闭Selinux策略

setenforce 0	#临时关闭

或者

vim /etc/selinux/config
#将SElinux设置为disabled,永久关闭
SELINUX=disabled 

8、重启ssh服务

systemctl restart sshd

9、测试

sftp sftpadmin@IP	#登录

以上就是在Linux下配置sftp的完整步骤,欢迎参考!
————————————————

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
搭建LinuxSFTP(Secure File Transfer Protocol)服务器需要以下步骤: 1. 安装OpenSSH服务器:首先要确保在Linux系统上安装了OpenSSH服务器。可以使用以下命令进行安装: ``` sudo apt-get install openssh-server ``` 2. 创建SFTP用户:使用以下命令创建一个新的用户,并将其用户根目录设置为SFTP目录: ``` sudo adduser sftp_user sudo usermod -d /sftp_folder sftp_user ``` 3. 配置OpenSSH服务器:编辑OpenSSH服务器的配置文件。可以使用以下命令打开配置文件: ``` sudo nano /etc/ssh/sshd_config ``` 在文件中找到以下行并取消注释(删除行首的#符号),并进行相应的修改: ``` Subsystem sftp internal-sftp Match User sftp_user ForceCommand internal-sftp ChrootDirectory /sftp_folder PermitTunnel no AllowAgentForwarding no AllowTcpForwarding no X11Forwarding no ``` 4. 重启OpenSSH服务器:完成配置后,使用以下命令重启OpenSSH服务器以应用更改: ``` sudo systemctl restart sshd ``` 5. 生成RSA密钥对(可选):可以为SFTP服务器生成RSA密钥对,以增强安全性。使用以下命令生成密钥对: ``` ssh-keygen -t rsa ``` 6. 配置SFTP用户的公钥:将生成的公钥(id_rsa.pub)复制到SFTP用户主目录的.ssh文件夹中,并将其重命名为authorized_keys: ``` sudo mkdir /sftp_folder/sftp_user/.ssh sudo cp id_rsa.pub /sftp_folder/sftp_user/.ssh/authorized_keys sudo chown sftp_user:sftp_user /sftp_folder/sftp_user/.ssh/authorized_keys ``` 确保.ssh文件夹和authorized_keys文件的权限正确设置: ``` sudo chmod 700 /sftp_folder/sftp_user/.ssh sudo chmod 600 /sftp_folder/sftp_user/.ssh/authorized_keys ``` 7. 完成:现在,您已经成功搭建了一个具有公私钥认证的SFTP服务器。可以使用SFTP客户端连接到该服务器并进行文件传输了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值