大神带你搭建FTP

Posted 看三年之后

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了大神带你搭建FTP相关的知识,希望对你有一定的参考价值。

一、FTP简介

FTP服务–用来传输文件的协议
FTP服务器默认使用TCP协议的20、21端口于客户端进行通信
20端口用于建立数据连接,并传输文件数据
21端口用于建立控制连接,并传输FTP控制命令
FTP数据连接分为主动模式和被动模式
主动模式:服务器主动发起数据连接
被动模式:服务器被动等待数据连接

二、搭建FTP

1、安装软件包

```html/xml
yum install -y vsftpd
rpm -qc vsftpd
cd /etc/vsftpd/
cp -p vsftpd.conf vsftpd.conf.bak

![image.png](https://s2.51cto.com/images/20220417/1650179271603713.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
![image.png](https://s2.51cto.com/images/20220417/1650179344359121.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
![image.png](https://s2.51cto.com/images/20220417/1650179451282330.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
#### 2、设置匿名用户访问的FTP服务(最大权限)
```html/xml
#修改配置文件
vim /etc/vsftpd/vsftpd.conf
anonymous_enable=YES            #开启匿名用户访问。默认已开启
write_enable=YES                #开放服务器的写权限(若要上传,必须开启)。默认已开启
anon_umask=022                  #设置匿名用户所上传数据的权限掩码(反掩码)。默认已开启
anon_upload_enable=YES          #允许匿名用户上传文件。默认已注释,需取消注释
anon_mkdir_write_enable=YES     #允许匿名用户创建(上传)目录。默认已注释,需取消注释
anon_other_write_enable =YES    #允许删除、重命名、覆盖等操作。需添加

#为匿名访问ftp的根目录下的 pub子目录设置最大权限,以便匿名用户上传数据
chmod 777 /var/ftp/pub/

#开启服务,关闭防火墙和增强型安全功能
systemctl start vsftpd
systemctl stop firewalld
setenforce 0

3、匿名访问测试

在Windows系统打开 开始 菜单,输入 cmd 命令打开命令提示符
#建立ftp连接
ftp 192.168.74.73
#匿名访问,用户名为ftp,密码为空,直接回车即可完成登录
ftp> pwd            #匿名访问ftp的根目录为Linux系统的/var/ftp/目录
ftp> ls             #查看当前目录
ftp> cd pub         #切换到pub 目录
ftp> get 文件名        #下载文件到当前Windows本地目录
ftp> put 文件名        #上传文件到ftp目录
ftp> quit           #退出



在客户端下载服务器里边的文件




4、设置本地用户验证访问ftp,并禁止切换到ftp以外的目录(默认登录的根目录为本地用户的家目录)

```html/xml
创建两个用户
lisi
zhangsan
#修改配置文件
vim /etc/vsftpd/vsftpd.conf
local_enable=Yes #启用本地用户
anonymous_enable=NO #关闭匿名用户访问
write_enable=YES #开放服务器的写权限(若要上传,必须开启)
anon_umask=077 #可设置仅宿主用户拥有被上传的文件的权限(反掩码)
chroot_local_user=YES #将访问禁锢在用户的宿主目录中
allow_writeable_chroot=YES 允许被限制的用户主目录具有写权限

重启服务
systemctl restart vsftpd

修改匿名用户、本地用户登录的默认根目录(这个在配置文件里填上即可,这就不演示了)
anon_root=/var/www/html #anon_root 针对匿名用户
local_root=/var/local/html #local_root 针对系统用户


![image.png](https://s2.51cto.com/images/20220418/1650263291564131.png?x-oss-process=image/wa![image.png](https://s2.51cto.com/images/20220418/1650263982636660.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)termark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x![image.png](https://s2.51cto.com/images/20220418/1650264025303459.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
进入配置文件
![image.png](https://s2.51cto.com/images/20220418/1650263436976270.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)

![image.png](https://s2.51cto.com/images/20220418/1650264133257049.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)

![image.png](https://s2.51cto.com/images/20220418/1650264041825124.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)

![image.png](https://s2.51cto.com/images/20220418/1650264218777684.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
切换张三用户
![image.png](https://s2.51cto.com/images/20220418/1650264437909262.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)

![image.png](https://s2.51cto.com/images/20220418/1650264345640674.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
![image.png](https://s2.51cto.com/images/20220418/1650265856281161.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
![image.png](https://s2.51cto.com/images/20220418/1650265921411633.png?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
## 三、总结
在生产中这个,会经常用到,大家在生产中做的时候一定要关掉防火墙,更改配置文件的时候一定要先备份一下。

以上是关于大神带你搭建FTP的主要内容,如果未能解决你的问题,请参考以下文章

实战-干货手把手带你搭建自己的FTP服务器,实现文件上传下载

linux下搭建ftp服务

centos 7 云计算服务器问题,求大神进

我想要在Linux环境下远程从windows下载一个文件到本地,我使用ftp和scp都不好用,求大神指点。

关于linux服务器上搭建ftp服务的流程

百晓生带你玩转linux系统服务搭建系列----pxe远程安装服务器的搭建及无人值守安装