Linux下如何部署FTP服务器
FTP 是 File Transfer Protocol 的缩写,即文件传输协议,它通过网络在服务器和客户端之间传输文件,现在已经成为一种广泛使用的标准工具
vsftpd 是 very secure ftp daemon 的缩写,它是 Linux 上使用最受欢迎、使用最广泛的 FTP 服务器之一,它具有安全,速度快,稳定的特点,很多重要的 FTP 站点比如 ftp.gnu.org
、ftp.freebsd.org
都是使用 vsftpd 作为服务器的
当前,FTP服务在日常工作中使用得也挺多,每次服务器版本更新都需要先打包,然后上传到线上的FTP服务器上,再从FTP服务器上下载服务器包到线上机器,进行MD5校验,然后就可以更新线上服务器了
说明
在安装 vsftpd 之前,有几个重要的地方需要说明下
工作模式
服务器使用两个端口和客户端通信,一个是命令端口,也叫控制端口,默认是 21, 用于命令的传输 ,一个是数据端口,默认是 20 ,用于数据的传输
- 主动模式
客户端向FTP服务器发送端口信息,由服务器主动连接该端口
流程:客户端和FTP服务器的命令端口(21)建立TCP连接,当需要传输数据时,客户端新启动一个用于数据传输的端口,并在命令端口的连接上用 PORT 命令告诉服务器该端口号,服务器与该端口建立TCP连接,连接成功之后,客户端开始传输数据
- 被动模式
FTP服务器开启并发送端口信息给客户端,由客户端连接该端口,服务器被动接受连接
流程:客户端和FTP服务器的命令端口(21)建立TCP连接,当需要传输数据时,服务器侦听一个用于数据传输的端口,并在命令端口的连接上用 PASV 命令告诉客户端该端口号,客户端与该端口建立TCP连接,连接成功之后,客户端开始传输数据
建议:
1、大多数FTP客户端都在局域网中,没有独立的公网IP地址,且有防火墙阻拦,主动模式下FTP服务器成功连接到客户端比较困难。因此,如无特殊需求,都是将FTP服务器配置为被动模式,本文后面的FTP服务器配置也是以被动模式为例的
2、被动模式下,命令端口和数据端口都是在FTP服务器端开启,也都可以通过启动配置来修改,由于默认的端口是公开的,安全性低,所以实际安装的时候都会修改默认端口
用户认证模式
- 匿名用户模式
任何人无需密码验证就可以直接登录到FTP服务器。这种模式最不安全,一般只用来保存不重要的公开文件,不推荐在生产环境中使用
- 本地用户模式
通过Linux系统本地账号进行验证的模式,相较于匿名用户模式更安全。
- 虚拟用户模式
FTP服务器的专有用户。虚拟用户只能访问Linux系统为其提供的FTP服务,而不能访问Linux系统的其它资源,进一步增强了FTP服务器的安全性。
匿名用户模式一般用于不重要的于公开文件,并且只提供下载服务,也就是说,用户只能下载,不能有其他操作,本地用户模式通过配置锁定目录、修改命令端口和数据端口 可以进一步增强安全性,本文后面的配置是以该模式为例的
安装
安装前可以使用下面的命令检查是否已安装
vsftpd -v
如果未安装会有如下提示
[root@localhost ~]$ vsftpd -v
-bash: vsftpd: 未找到命令
安装 vsftpd
yum install vsftpd
安装完成后,执行 vsftpd -v
命令,如果输出版本号,表示安装成功
[root@localhost ~]# vsftpd -v
vsftpd: version 3.0.2
配置服务器
安装完成之后,默认的配置位于 /etc/vsftpd/vsftpd.conf
, 如果找不到默认配置在哪里,可以使用下面的命令查找下,其中 /etc/vsftpd
目录就是存放配置的地方
[root@localhost ~]# whereis vsftpd
vsftpd: /usr/sbin/vsftpd /etc/vsftpd /usr/share/man/man8/vsftpd.8.gz
配置的格式相对简单,每一行都是注释或者选项,注释以 #
号开头,选项的格式是 option=value
的形式,每个选项占一行,option
、=
以及 value
之间不允许出现空格
vsftpd 对每个配置的选项都设置了一个默认值,服务器启动之后,在 vsftpd.conf
中配置的选项会覆盖服务器中的默认值
vsftpd 可配置的选项很多,下面按照类别把常用的配置项分成了 访问权限、锁定访问目录、限定用户登录、修改端口、日志配置、其他配置 几组, 每个配置项前都增加了详细的说明
配置项分组主要是为了总结说明每一组配置项的作用,实际配置的过程中,把所有组的配置项添加到 vsftp.conf
中即可
- 访问权限
#是否允许匿名登录,默认允许,如果允许,用户名 ftp 和 anonymous 都会被当做匿名登录
#为了安全,一般不允许匿名登录
anonymous_enable=NO
#是否允许匿名上传,默认不允许,如果允许 write_enable 选项需要设置为 YES
#为了安全,一般不允许
anon_upload_enable=NO
#是否允许本地用户登录,默认不允许,如果允许,在 ``` /etc/passwd``` 中的用户都可以登录 FTP 服务器
#如果不予许匿名登录的话,这个选项需要设置为允许
local_enable=YES
#是否允许在FTP服务器上写入, 默认不允许,如果有上传文件、删除文件等需求,一般都是开启的
write_enable=YES
#设置写入服务器文件的权限掩码值,如果值是八进制需要以 0 开头,否则会当作十进制
#值为 022,能满足大部分FTP的需求
local_umask=022
- 锁定访问目录
#默认为 NO, 如果设置为 YES,表示用户通过FTP客户端登录之后
#只能在FTP服务器指定的目录中,不允许切出目录,
chroot_local_user=YES
#用户名插入到本地 FTP 主目录中
user_sub_token=$USER
#定义用户 FTP 主目录,用户登录成功之后,vsftpd 服务器会切换到此目录,
#此时 FTP 客户端会位于此目录中,后续的上传以及下载都是针对这个目录的
local_root=/home/$USER/ftp
把登录的用户锁定在指定的目录中,避免用户访问不应该访问的目录,这里我们设置成只允许访问自己的 home 目录中的 ftp 目录,例如:新添加一个用户 testuser
专门用于上传下载, testuser
通过 FTP 客户端成功登录后,会自动切换到 /home/testuser/ftp
目录,并且不允许切出该目录
注意:用户上传和下载都是在限定的目录中,所以一般都是把锁定目录设置到剩余空间比较大的磁盘中
- 限定用户登录
#如果设置为 YES ,vsftpd 将会从 userlist_file 选项指定的文件读取用户列表
userlist_enable=YES
#设置用户列表配置文件, 如果 /etc/vsftpd/user_list 不存在需要手工创建
userlist_file=/etc/vsftpd/user_list
#此选项检查 userlist_enable 选项,当 userlist_enable 为 YES 时
#如果 userlist_deny 设置为 NO , 表示只允许 userlist_file 中的用户登录
#如果 userlist_deny 设置为 YES, 表示禁止 userlist_file 中的用户登录,允许其他用户登录
userlist_deny=NO
- 修改端口
#如果启用,vsftpd 将在独立模式下运行,vsftpd 本身将负责侦听和处理传入的连接
listen=NO
# 跟 listen 选型类似,但是此选项是侦听在 IPV6 上的 socket
# 而 listen 是 IPV4, 此选项和 listen 是互斥的,不能同时设置为 YES
listen_ipv6=YES
#服务器侦听端口,也是命令端口, 默认是21,修改之后, 防火墙需要做相应的调整
#同时 FTP 客户端登录的时候需要指定端口号
#为了增强安全性,配置的时候一般都会修改
listen_port=48888
#开启被动模式
pasv_enable=YES
#被动模式下,服务器的地址,默认是内网地址
#如果在云服务器上部署,需要修改成公网IP
pasv_address=192.168.70.20
#设置被动模式下,建立数据传输可使用的端口范围的最小值。
#建议把端口范围设置在一段比较高的范围内,例如50000~50010,有助于提高访问FTP服务器的安全性
pasv_min_port=50000
#设置被动模式下,建立数据传输可使用的端口范围的最大值
pasv_max_port=50010
- 日志配置
#是否记录上传下载日志,默认是不记录,如果设置为记录
#默认日志文件位于 /var/log/vsftpd.log, 如果配置了 vsftpd_log_file 选项,会覆盖默认日志文件
xferlog_enable=YES
#记录上传下载的日志
xferlog_file=/var/log/xferlog
#是否按照标准格式记录日志
xferlog_std_format=YES
- 其他配置
# vsftpd 使用的 PAM 服务名字
pam_service_name=vsftpd
#
tcp_wrappers=YES
这两个配置使用默认生成的选项即可,不用做任何修改
设置防火墙
如果你部署的FTP服务器的机器上防火墙是关闭状态的话,可以跳过此步骤,或者你不想设置防火墙的话,可以通过 systemctl stop firewalld
命令关闭防火墙,这样也可以忽略此步骤
上面配置中服务器侦听端口(也叫命令端口) listen_port
选项设置的是 48888
,数据端口的范围是 50000-50010
, 所以防火墙需要开放这些端口,执行以下命令即可设置
[root@localhost ~]# firewall-cmd --zone=public --add-port=48888/tcp --permanent
success
[root@localhost ~]# firewall-cmd --zone=public --add-port=50000-50010/tcp --permanent
success
防火墙设置好以后,执行下面的命令重启防火墙服务
[root@localhost ~]# systemctl restart firewalld
最后,查看下端口是否成功开放
[root@localhost ~]# firewall-cmd --list-port
50000-50010/tcp 48888/tcp
从结果可以看出,防火墙已经开放了 48888、50000-50099
端口
启动服务器
配置完 /etc/vsftpd/vsftpd.conf
,设置好防火墙之后,执行下面的命令启动服务器
systemctl start vsftpd
启动之后,查询服务器状态,确认服务器是否启动成功
[root@localhost ~]# systemctl status vsftpd
● vsftpd.service - Vsftpd ftp daemon
Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; enabled; vendor preset: disabled)
Active: active (running) since Fri 2021-09-1 20:21:00 CST; 3 days ago
Main PID: 94916 (vsftpd)
CGroup: /system.slice/vsftpd.service
└─94916 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
Sep 1 20:21:00 localhost systemd[1]: Starting Vsftpd ftp daemon...
Sep 1 20:21:00 localhost systemd[1]: Started Vsftpd ftp daemon.
将服务器设置成开机启动
systemctl enable vsftpd
下面的命令可以确认服务器的命令端口是否开启( 配置的是 : 48888 )
[root@localhost ~]# netstat -antup | grep vsftpd
tcp6 0 0 :::48888 :::* LISTEN 20501/vsftpd
[root@localhost ~]#
新建FTP用户
新建用户 mytest
, 并设置密码
[root@localhost ~]# useradd mytest
[root@localhost ~]# passwd mytest
新建 FTP 目录,并修改目录权限
[root@cghost21 home]# mkdir -p /home/mytest/ftp/files
[root@cghost21 home]# chmod -R 500 /home/mytest/
[root@cghost21 home]# chmod -R 700 /home/mytest/ftp/files
注意:/home/mytest/ftp 是 mytest 用户的锁定目录,mytest 登录之后,只能呆在此目录以及此目录的子目录中,不允许切换到其他目录
锁定目录必须要去掉可写权限,不然用户会无法登录,这一点在FTP服务器端做了强制的校验,所以 "chmod 500 /home/mytest/" 命令是设置 /home/mytest 以及 /home/mytest/ftp 两个目录可读可执行权限,无可写权限
"/home/mytest/ftp/files" 目录是实际的上传下载的目录,所以需要有可读写和可执行权限
最后,还需要把用户名加入到FTP服务器允许登录的用户列表中,也即 /etc/vsftpd/vsftpd.conf
中 userlist_file
选项对应的文件 /etc/vsftpd/user_list
中,如果 user_list
不存在,需要手工创建并把 mytest
添加进去
测试
服务器全部搭建好之后,需要进行测试,这里我准备的 FTP服务器的IP是 192.168.70.20
, FTP客户端机器的IP是 192.168.70.11
进入FTP服务器的 /home/mytest/ftp/files
目录, 新建一个 a.txt
测试文件
[root@localhost files]# pwd
/home/mytest/ftp/files
[root@localhost files]# echo "ftp server..." >> a.txt
[root@localhost files]#
进入FTP客户端机器的 /home/wl/temp
目录,新建一个 test.txt
测试文件
[root@localhost temp]# echo "ftp test..." >> test.txt
[root@localhost temp]# cat test.txt
ftp test...
测试上传下载需在FTP客户端机器上安装 FTP 客户端, 执行以下命令进行安装,如已安装,可忽略
yum install ftp
执行下面一系列的命令,进行测试
1、登录FTP服务器命令,格式:ftp 服务器ID 命令端口
2、输入登录用户名
3、输入登录密码
4、登录成功之后,此时位于FTP服务器的 /home/mytest/ftp 目录中,执行 ls 命令之后,
结果显示当前目录还有一个 files 的子目录
5、执行 pwd 命令查看当前所在目录,FTP服务器上的 /home/mytest/ftp 目录就是 FTP 的根目录
6、执行 cd files 命令进入 files 目录,也即FTP服务器上的 /home/mytest/ftp/files 目录,
然后执行 ls 命令查看当前目录的文件,可以看到 FTP服务器上的测试文件 a.txt
7、执行 put test.txt 命令,把FTP客户端机器上当前目录( /home/wl/temp ) 中的 test.txt 文件
上传到服务器的 /home/mytest/ftp/files 目录中
8、执行 get a.txt 命令,把FTP服务器上的 /home/mytest/ftp/files/a.txt 文件下载到 FTP客户端机器的当前目录( /home/wl/temp ) 中
9、上传下载测试完成之后,执行 exit 命令,退出 FTP 命令行
10、最后执行 cat a.txt 命令查看从 FTP服务器上下载的测试文件的内容,从结果可以看出,和服务器上的测试文件内容是一样的
小结
本文介绍了 Linux 下FTP服务器 vsftpd 的安装、配置、测试等整个步骤以及注意事项,文中只是对 vsftpd 的常用配置项做了说明,更多的配置项请参考官网文档
Linux下如何部署FTP服务器的更多相关文章
- LINUX下如何开启FTP服务器
1.首先应开启linuxh环境下的FTP service,过程如下: http://www.witech.com.cn/news/Article_Show.asp?ArticleID=48 ...
- Linux下部署FTP服务器
Linux下部署FTP服务器 下载安装包 在这里介绍的是离线部署FTP,首先下载对应的rpm包,下载链接为: 下载vsftpd服务 下载FTP客户端 安装ftp服务器 关闭防火墙 service ip ...
- linux下使用docker方式部署ftp服务器
linux环境下部署vsftpd比较繁琐,可以直接使用docker官方仓库中的pure-ftpd镜像来部署ftp服务器. 下载镜像 docker pull stilliard/pure-ftpd:ha ...
- Linux安装部署FTP服务器
Linux安装部署FTP服务器 本文章会将安装FTP服务器的步骤以及一些遇到的问题来记录下 因为项目中要与第三方对接数据,需要用到FTP服务器以提供他们每天上传数据,因为之前在本地的VMware虚 ...
- 1 Linux平台下快速搭建FTP服务器 win7下如何建立ftp服务器
百度经验连接(亲测可用) http://jingyan.baidu.com/article/380abd0a77ae041d90192cf4.html win7下如何建立ftp服务器 http://j ...
- linux下安装部署ansible
linux下安装部署ansible 介绍 Ansible是一种批量部署工具,现在运维人员用的最多的三种开源集中化管理工具有:puppet,saltstack,ansible,各有各的优缺点,其中sal ...
- 在Linux中搭建一个FTP服务器
在Linux中搭建一个ftp服务器,以供两个工作小组保管文件使用.禁用匿名.第一个小组使用ftp账号:ftp1,工作目录在:/var/ftp/ftp1:第二个小组使用ftp2,工作目录在:/var/f ...
- CentOS 6.5下快速搭建ftp服务器[转]
CentOS 6.5下快速搭建ftp服务器 1.用root 进入系统 2.使用命令 rpm -qa|grep vsftpd 查看系统是否安装了ftp,若安装了vsftp,使用这个命令会在屏幕上显示vs ...
- Linux中搭建一个ftp服务器详解
来源:Linux社区 作者:luzhi1024 详解Linux中搭建一个ftp服务器. ftp工作是会启动两个通道:控制通道 , 数据通道在ftp协议中,控制连接均是由客户端发起的,而数据连接有两种 ...
随机推荐
- 理解JMX之介绍和简单使用
JMX最常见的场景是监控Java程序的基本信息和运行情况,任何Java程序都可以开启JMX,然后使用JConsole或Visual VM进行预览.下图是使用Jconsle通过JMX查看Java程序的运 ...
- 看看线程特有对象ThreadLocal
作用:设计线程安全的一种技术. 在使用多线程的时候,如果多个线程要共享一个非线程安全的对象,常用的手段是借助锁来实现线程的安全.线程安全隐患的前提是多线程共享一个不安全的对象 ,那么有没有办法让线程之 ...
- Nginx编译添加新模块
目录 一.简介与思路 一.简介与思路 当前适用于nginx已经在安装过了,如果没安装过,直接在编译时候添加模块即可. Nginx主要程序就是nginx这个二进制脚本,只要在编译一个nginx脚本替换掉 ...
- Nginx 中 location 的匹配顺序
nginx中location的匹配模式有以下几种: 精确匹配:以=开头,只有完全匹配才能生效,例子location = /uri 非正则匹配:以^~开头,^表示非.~表示正则,例子location ^ ...
- 离散数学3.1&&3.3
离散数学 当前所使用的数字电脑是离散的,二进制指令,传输到内存 早先使用的模拟电脑是连续的 判断是否是命题(两个步骤)[不要跳步骤] 陈述句 要么是真命题要么是假命题 真假性 真:用T或1表示,假:用 ...
- Docker 安装&卸载
不同版本可能有差异具体信息查看官网 官网:https://docs.docker.com/engine/install/centos/ #环境准备 #查看环境 uname -r # 系统内核在3.10 ...
- 在【自定义列】中编辑简单运算公式(Power Query 之 M 语言)
数据源: "品名"."数量"."单价"三列 目标: 计算销售单价(单价*1.2) 解决方案: 在[自定义列]中使用乘法四则运算 步骤: 打开 ...
- CF946B Weird Subtraction Process 题解
Content 有两个数 \(a,b\),执行如下操作: 如果 \(a,b\) 中有一个数是 \(0\),结束操作,否则跳到操作 \(2\). 如果 \(a\geqslant 2b\),那么 \(a\ ...
- CF1097B Petr and a Combination Lock 题解
Content 有一个锁,它只有指针再次指到 \(0\) 刻度处才可以开锁(起始状态如图所示,一圈 \(360\) 度). 以下给出 \(n\) 个操作及每次转动度数,如果可以通过逆时针或顺时针再次转 ...
- IDEA设置maven打包的时候跳过单元测试
pom增加插件 <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>mav ...