Linux搭建FTP服务器

一、概念简介

vsftpd(very secure FTP daemon)是Linux下的一款小巧轻快、安全易用的FTP服务器软件,本次实验介绍如何在Linux上安装并配置vsftpd。

FTP(File Transfer Protocol)是一种文件传输协议,基于客户端/服务器架构,支持以下两种工作模式:

主动模式:客户端向FTP服务器发送端口信息,由服务器主动连接该端口。

被动模式:FTP服务器开启并发送端口信息给客户端,由客户端连接该端口,服务器被动接受连接。

FTP支持以下三种认证模式:

匿名用户模式:任何人无需密码验证就可以直接登录到FTP服务器,这种模式最不安全,一般只用来保存不重要的公开文件,不推荐在生产环境中使用。

本地用户模式:通过Linux系统本地账号进行验证的模式,相较于匿名用户模式更安全。

虚拟用户模式:FTP服务器的专有用户,虚拟用户只能访问Linux系统为其提供的FTP服务,而不能访问Linux系统的其它资源,进一步增强了FTP服务器的安全性。

二、搭建FTP服务器
1、运行命令安装vsftp

复制代码
apt-get install vsftpd
或者
yum install vsftpd

安装成功后一般会自动启动。
2、检查是否安装成功

复制代码
dpkg -l | grep vsftpd

或者

复制代码
rpm -qa | grep vsftpd


3、查看FTP服务监听的端口

复制代码
netstat -antup | grep ftp

如图所示,代表FTP服务已经启动,监听的端口号是21,vsftpd默认已开启本地用户模式,下面我们需要继续配置用户名密码文件目录才能使用FTP服务。

4、其他常用的ftp命令

复制代码
service vsftpd status    #查看FTP服务运行状态
复制代码
systemctl list-unit-files | grep vsftpd    #查看FTP服务是否开机自启动
复制代码
systemctl enable vsftpd.service    #设置FTP服务开机自启动

systemctl start vsftpd   #启动ftp

三修改配置文件

复制代码
vim /etc/vsftpd.conf

local_enable=YES  #本地用户登录
write_enable=YES  #允许上传,通常会设置为NO
chroot_local_user=YES
chroot_list_enable=YES
utf8_filesystem=YES  #linux的专用编码
chroot_list_file=/etc/vsftpd.chroot_list      #指定了chroot_list_file列表的路径和名称。一行一个用户名
local_root=/home/desktop     #设置fpt的默认下载目录,也即FTP用户的本地根目录,FTP用户登录后,其工作目录将被限制在该目录及其子目录下。

四、配置vsftpd
1、设置用户

运行以下命令为FTP服务创建一个Linux用户,本示例中,该用户名为ftptest

出现"新的密码"时输入密码即可

如需修改密码可以运行一下命令,根据命令行提示完成FTP用户的密码修改

复制代码
passwd ftptest

2、添加vsftpd.chroot_list

编辑/etc/vsftpd.chroot_list文件,用于存放允许ftp访问的地址,从名字不难看出,这是一个链表。

输入如下命令

复制代码
sudo vim /etc/vsftpd.chroot_list

将刚刚创建的文件夹名字添加进去,这里我创建的是ftptest,可以添加多个。

五、重启ftp服务

重启ftp服务

使用命令重启ftp服务

复制代码
sudo service vsftpd restart

六、使用

方式1:ftp://192.168.100.20连接FTP服务器,用户名:ftptest ;密码:设置的密码

打开一个文件夹,在地址栏输入ftp://ip,会弹出输入用户名密码的界面,输入后点击确定

方式2:使用winscp

方式3:使用FTP客户端

相关推荐
weixin_461259413 分钟前
[C]C语言日志系统宏技巧解析
java·服务器·c语言
m0_637146938 分钟前
C语言基础面试问答
运维·服务器
t1987512812 分钟前
Linux 上的 Tomcat 端口占用排查
linux·tomcat·firefox
小狗爱吃黄桃罐头32 分钟前
正点原子[第三期]Arm(iMX6U)Linux移植学习笔记-12.1 Linux内核启动流程简介
linux·arm开发·学习
Clownseven1 小时前
SSH/RDP无法远程连接?腾讯云CVM及通用服务器连接失败原因与超全排查指南
服务器·ssh·腾讯云
ricky_fan1 小时前
window下配置ssh免密登录服务器
运维·服务器·ssh
地衣君1 小时前
Ubuntu 配置使用 zsh + 插件配置 + oh-my-zsh 美化过程
linux·运维·ubuntu
2401_858286111 小时前
OS11.【Linux】vim文本编辑器
linux·运维·服务器·编辑器·vim
朱包林2 小时前
day27-shell编程(自动化)
linux·运维·服务器·网络·shell脚本
钢铁男儿2 小时前
一文掌握 Tombola 抽象基类的自动化子类测试策略
运维·自动化