CentOS7下FTP的安装配置

简介:

一、安装VSFTP

      在开源操作系统中常用的FTPD套件主要还有vsftp、ProFTPD、PureFTPd和wuftpd等。

      vsftpd 是"very secure FTP daemon"的缩写,安全性是它的一个最大的特点。vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行在诸如 Linux、BSD、Solaris、 HP-UNIX等系统上面,是一个完全免费的、开发源代码的ftp服务器软件,支持很多其他的 FTP 服务器所不支持的特征。比如:非常高的安全性需求、带宽限制、良好的可伸缩性、可创建虚拟用户、支持IPv6、速率高等。

vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特点是小巧轻快,安全易用。

     附vsftp的wiki:

                   https://en.wikipedia.org/wiki/Vsftpd

1
2
# yum -y install vsftpd       ##直接yum安装
# systemctl start vsftpd.service       ##启动vsftp服务器



二、配置VSFTP

     vsftpd提供了standalone和inetd(inetd或xinetd)两种运行模式。standalone一次性启动,运行期间一直驻留在内存中,优点是对接入信号反应快,缺点是损耗了一定的系统资源,经常应用于对实时反应要求较高的专业FTP服务器;inetd恰恰相反,由于只在外部连接发送请求时才调用FTP进程,因此不适合应用在同时连接数量较多的系统。此外,inetd模式不占用系统资源。

1
[root@localhost ~] # vi /etc/xinetd.d/vsftpd

wKioL1XsAT7Srka4AAFUoZYHt64085.jpg


wait = 0 表示设备是激活的,它正在使用标准的TCP Sockets。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@localhost ~] # cat /etc/vsftpd/vsftpd.conf |grep ^[^#]          ##查看其默认配置
anonymous_enable=YES               ##允许匿名账号登录
local_enable=YES                   ##允许本地用户(即linux系统中的用户帐号)
write_enable=YES                 ##允许本地用户对FTP服务器文件具有写权限
local_umask=022                      ##设置本地用户默认文件掩码022
dirmessage_enable=YES                 ##激活目录欢迎信息功能
xferlog_enable=YES                   ##激活上传、下载日志文件,默认在/var/log/vsftpd.log下
connect_from_port_20=YES                 ##启用FTP数据端口的连接请求
xferlog_std_format=YES              ##以标准xferlog的格式书写传输日志文件
listen=NO                    ##关闭监听(开启vsftpd将以独立模式运行,由vsftpd自己监听和处理                                          IPv4端口的连接请求)
listen_ipv6=YES                  ##开启IPv6端口监听
pam_service_name=vsftpd          ##设置PAM外挂模块提供的认证服务所使用的配置文件名,                                            即/etc/pam.d/vsftpd文件
userlist_enable=YES                ###允许ftpusers文件中的用户登录FTP服务器
tcp_wrappers=YES                    ##使用tcp_wrappers作为主机访问控制方式(tcp_wrappers
                                       可以实现linux系统中网络服务的基于主机地址的访问控制)


三、关闭SELinux和防火墙

a、临时关闭(不用重启机器): 

1
2
# setenforce 0                       ##设置SELinux 成为permissive模式  (关闭SELinux)
# setenforce 1                       ##设置SELinux 成为enforcing模式     (开启SELinux)

    

b、修改配置文件需要重启机器:

1
# vi /etc/selinux/config

   


将SELINUX=enforcing 改为SELINUX=disabled(需重启机器)


c、可自己做策略开放相应端口,这里我直接关闭:

1
2
# systemctl status firewalld.service       ##查看防火墙状态
# systemctl stop firewalld.service         ##关闭防火墙


四、客户端登录验证


Ubuntu登录:

wKioL1XuUQPR7fMGAAFooG7nWwY466.jpg


Windows登录:

wKiom1XuUMbzbWt1AAE5Dk5eqWg800.jpg


网页登录:

wKiom1XuVCfhfTB_AAEm3IbwDTQ247.jpg


五、VSFTP应用

默认的,ftp的根目录在服务器的/var/ftp下.


1
[root@localhost ~] # echo "abcd" >/var/ftp/123.txt

wKiom1XuVtvDHeD1AAEu8VHsy84116.jpg


1.使用help命令查看帮助

wKioL1XuWyThAPe0AADVQCmSo9Y129.jpg


2.使用put命令上传,get命令下载(账号:anonymous,密码为空)

wKioL1XuWRvT6jHzAAFzY8CWmws928.jpg


①提示找不到文件,原因:该文件没有在当前目录下,使用lcd命令查看

②将文件移动至当前目录下进行上传操作,提示550,原因:没有开放权限,不能上传

③从ftp服务器下载文件,提示226,下载成功


3.更改vsftp.conf的设置,使其允许匿名用户下载:

1
2
3
4
5
6
7
8
9
# vi /etc/vsftpd/vsftpd.conf
anon_upload_enable=YES           ##允许匿名用户上传文件(须将全局的write_enable=YES,默认YES)
anon_mkdir_write_enable=YES          ##允许匿名用户创建目录
use_localtime=YES                  ##使用本地时(自行添加)
anon_umask=022                      ##设置匿名用户的掩码(自行添加)
anon_other_write_enable=YES        ##允许匿名用户删除和重命名权限(自行添加)
# mkdir /var/ftp/upload         ##在/var/ftp下新建一个目录来实现匿名用户上传
# chmod -R 777 /var/ftp/upload/    ##赋予其权限
# systemctl restart vsftpd.service     ##重启vsftp

wKiom1Xuc7SR6GeJAAJEF6GPLSU462.jpg

wKioL1XudqbSupqPAAFv6koMAlg451.jpg


状态码:

230-----登录成功

200-----命令执行成功

150-----文件状态正常,开启数据连接端口

250-----目录切换操作完成

226-----关闭数据连接端口,请求的文件操作成功

wKioL1XueMbgITP7AAFHqGRk2Ws183.jpg



wKiom1XufEjTfEJaAABomoduP24873.jpg

mkdir------>创建目录文件

delete------>删除文件

rm------>删除目录文件


wKioL1XufqKgsRPXAAE8bgtsYkY713.jpg

附1:SFTP

     SFTP是Secure File Transfer Protocol的缩写,安全文件传送协议,可以为传输文件提供一种安全的加密方法。SFTP是SSH的一部份,在SSH软件包中,已经包含了一个叫作SFTP(Secure File Transfer Protocol)的安全文件传输子系统,SFTP本身没有单独的守护进程,它必须使用sshd守护进程(端口号默认是22)来完成相应的连接操作,所以从某种意义上来说,SFTP并不像一个服务器程序,而更像是一个客户端程序。SFTP同样是使用加密传输认证信息和传输的数据,所以,使用SFTP是非常安全的。

    SFTP连接方法跟FTP连接方法相同。

wKioL1XuqSyjUt1lAAJ2JEwcw-s084.jpg



附2:Ubuntu下安装vsftp的wiki:

1
http: //wiki .ubuntu.com.cn /Vsftpd


附3:vsftpd配置详解


本文转自  结束的伤感  51CTO博客,原文链接:http://blog.51cto.com/wangzhijian/1692834



相关文章
|
3月前
|
应用服务中间件 Linux 网络安全
centos7 下离线安装gcc g++ nginx,并配置nginx进行网络流转发
centos7 下离线安装gcc g++ nginx,并配置nginx进行网络流转发
113 0
|
1月前
File和FTP和HTTP软件配置
File和FTP和HTTP软件配置
|
1月前
|
Java Linux
Flume【环境搭建 01】CentOS Linux release 7.5 安装配置 apache-flume-1.9.0 并验证
【2月更文挑战第16天】Flume【环境搭建 01】CentOS Linux release 7.5 安装配置 apache-flume-1.9.0 并验证
34 0
|
1月前
|
分布式计算 关系型数据库 MySQL
Sqoop【部署 01】CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
【2月更文挑战第8天】Sqoop CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
100 1
|
4天前
|
运维 网络协议 Linux
【运维系列】Centos7安装并配置PXE服务
PXE是Intel开发的预启动执行环境,允许工作站通过网络从远程服务器启动操作系统。它依赖DHCP分配IP,DNS服务分配主机名,TFTP提供引导程序,HTTP/FTP/NFS提供安装源。要部署PXE服务器,需关闭selinux和防火墙,安装dhcpd、httpd、tftp、xinetd及相关服务,配置引导文件和Centos7安装源。最后,通过syslinux安装引导文件,并创建pxelinux.cfg/default配置文件来定义启动参数。
15 0
|
4天前
|
运维 网络协议 Linux
【运维系列】Centos7安装并配置postfix服务
安装CentOS7的Postfix和Dovecot,配置Postfix的`main.cf`文件,包括修改完全域名、允许所有IP、启用邮箱等。然后,配置Dovecot的多个配置文件以启用auth服务和调整相关设置。重启Postfix和Dovecot,设置开机自启,并关闭防火墙进行测试。最后,创建邮箱账户并在Windows邮箱客户端中添加账户设置。
10 0
|
4天前
|
运维 Linux 网络安全
【运维系列】Centos7安装配置ntp服务
配置yum并安装ntp,编辑ntp配置文件,取消17行注释,适应本机网段,22行设置使用本地时间。关闭防火墙,重启ntp服务。测试时先关闭防火墙,然后使用ntpdate命令成功同步时间。
13 0
|
4天前
|
Linux 网络安全
Centos6.5安装并配置NFS服务
该内容描述了在Linux系统中设置NFS服务的步骤。首先挂载yum源,然后安装NFS服务,并编辑配置文件。接着,重启rpcbind和NFS服务,可能需要重复此过程以解决初始可能出现的问题。此外,关闭防火墙策略,并再次重启服务。最终,根目录被共享,特定IP网段被允许访问。
11 0
|
18天前
|
网络协议
centos8 网卡 Nmcli(是network的简写 Nmcli)配置网络
centos8 网卡 Nmcli(是network的简写 Nmcli)配置网络
17 0
|
22天前
|
Ubuntu 网络安全 数据安全/隐私保护
ubuntu篇-配置FTP服务,本机和docker安装
通过以上步骤,你可以在Ubuntu上配置FTP服务,无论是本机安装还是Docker内安装,都可以提供FTP文件传输服务。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
22 1