Centos6.8:vsftpd安装与配置

本文涉及的产品
运维安全中心(堡垒机),免费版 6个月
运维安全中心(堡垒机),企业双擎版 50资产 7天
日志服务 SLS,月写入数据量 50GB 1个月
简介:

vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特点是小巧轻快,安全易用,具有非常高的安全性需求、带宽限制、良好的可伸缩性、可创建虚拟用户、支持IPv6、速率高等特点


1. 下载安装vsftpd服务,使用yum即可,db4用来支持文件数据库

yum install -y vsftpd db4-utils

2. 建立宿主用户vsftpd,因为默认的Vsftpd的服务宿主用户是root,但是这不符合安全性的需要。这里建立名字为vsftpd的用户,用他来作为支持Vsftpd的服务宿主用户,即运行vsftpd服务的是vsftpd。由于该用户仅用来支持Vsftpd服务用,因此没有许可他登陆系统的必要,并设定他为不能登陆系统的用户

useradd -s /sbin/nologin -M vsftpd

3. 建立ftp虚拟宿主用户,Vsftp的虚拟用户,虚拟用户并不是系统用户,也就是说这些FTP的用户在系统中是不存在的。他们的总体权限其实是集中寄托在一个在系统中的某一个用户身上的,所谓Vsftpd的虚拟宿主用户,就是这样一个支持着所有虚拟用户的宿主用户。由于他支撑了FTP的所有虚拟的用户,那么他本身的权限将会影响着这些虚拟的用户,因此,处于安全性的考虑,也要非分注意对该用户的权限的控制,该用户也绝对没有登陆系统的必要,这里也设定他为不能登陆系统的用户。

useradd -s /sbin/nologin -M peng

4. 编辑vsftpd配置文件

cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
vim /etc/vsftp/vsftpd.conf
--------------------------------------------------------------
anonymous_enable=NO            #   设定禁止匿名访问
anon_upload_enable=NO           #   设定禁止匿名上传
anon_mkdir_write_enable=NO         #   设定禁止匿名创建目录
xferlog_enable=YES             #   开启日志记录功能
xferlog_file=/var/log/vsftpd.log      #   设定vsftpd服务日志报错路径,需要手动touch,由于这里更改了服务启动用户,所以需要给vsftpd用户写入权限
xferlog_std_format=YES           #   设定日志使用标准记录格式
local_enable=YES              #   设定本地用户可以访问,如果为NO,虚拟用户也无法访问
write_enable=YES              #   设定可以进行写操作
chown_uploads=NO              #   禁止上传文件更改宿主

chroot_list_enable=NO           # 设置是否启用chroot_list_file配置项指定的用户列表文件。默认值为NO
chroot_list_file=/etc/vsftpd.chroot_list    # 用于指定用户列表文件,该文件用于控制哪些用户可以切换到用户家目录的上级目录
chroot_local_user=YES                      # 用于指定用户列表文件中的用户是否允许切换到上级目录。默认值为NO  
nopriv_user=vsftpd             #  设定支撑vsftpd服务的宿主用户,即运行vsftpd服务的是vsfptd用户,这里要注意写入权限,比如日志文件     
local_umask=022              #   设定上传后的权限掩码为022
pam_service_name=vsftpd          #  设置PAM使用的名称,默认值为/etc/pam.d/vsftpd
userlist_enable=YES            #  userlist_file中的用户将不得登录FTP
guest_enable=YES            #  设定启用虚拟用户功能
guest_username=peng            #  指定虚拟用户的宿主用户
virtual_use_local_privs=YES        #  当该参数激活(YES)时,虚拟用户使用与本地用户相同的权限
user_config_dir=/etc/vsftpd/user_conf   #  设定虚拟用户个人Vsftp的配置文件存放路径,这些配置文件名必须和虚拟用户名相同
connect_from_port_20=YES          #   设定端口20进行数据连接
dirmessage_enable=YES           #   开启目录标语功能

#idle_session_timeout=600         # 设置多长时间不对FTP服务器进行任何操作,则断开该FTP连接,单位为秒。默认值为300
#data_connection_timeout=120        # 设置建立FTP数据连接的超时时间,单位为秒。默认值为120
#accept_timeout=60             # 设置建立FTP连接的超时时间,单位为秒。默认值为60
async_abor_enable=YES           # 设定支持异步传输功能
ascii_upload_enable=YES          # 设定支持ascii上传
ascii_download_enable=YES         # 设定支持ascii下载
ftpd_banner='Welcome'           # 设定ftp登录欢迎语
ls_recurse_enable=NO            # 禁止用户登陆FTP后使用"ls -R"的命令。该命令会对服务器性能造成巨大开销
listen=YES                 # 设定该Vsftpd服务工作在StandAlone模式下,所谓StandAlone模式就是该服务拥有自己的守护进程支持
tcp_wrappers=YES              # vsftpd服务器会检查/etc/hosts.allow 和/etc/hosts.deny 中的设置,来决定请求连接的主机,是否允许访问该FTP服务器
#比如允许192.168.1.0这个网段访问vsftpd服务,在hosts.allow添加
#vsftpd:192.168.0. :allow
local_max_rate=0    #  本地用户使用的最大传输速度,单位为B/s,0 表示不限制速度。预设值为0

5. 建立vsftpd日志文件,并赋予相关的权利

touch /var/log/vsftpd.log
chown vsftpd:vsfptd /var/log/vsftpd.log
mkdir /etc/vsftpd/user_conf

6. 制作虚拟用户数据库文件

#    先建立虚拟用户名单,这个文件就是来记录vsftpd虚拟用户的用户名和口令的数据文件
touch /etc/vsftpd/virtusers
#    编辑虚拟用户名单,添加可访问的用户和密码,一行一用户,一行一密码
echo -e 'user1\n123456' >> /etc/vsftpd/virtusers
#    生成虚拟用户数据文件
db_load -T -t hash -f /etc/vsftpd/virtusers /etc/vsftpd/virtusers.db
#    查看生成的用户数据文件
ll /etc/vsftpd/virtusers.db
#    如果以后再添加虚拟用户,需要再执行生成一次虚拟用户数据文件

7. 设定PAM验证文件,并指定虚拟用户数据文件读取

#    在编辑前备份
cp /etc/pam.d/vsftpd /etc/pam.d/vsftpd.bak
vim /etc/pam.d/vsftpd
#    添加俩行,目的是对虚拟用户和账号权限进行验证
auth    sufficient    /lib64/security/pam_userdb.so    db=/etc/vsftpd/virtusers
account sufficient /lib64/security/pam_userdb.so   db=/etc/vsftpd/virtusers

8. 虚拟用户的配置

#    规划好虚拟用户的主路径
mkdir /opt/vsftpd
#    建立测试用户的FTP主目录
mkdir /opt/vsftpd/user1
#    定制测试用户的配置文件
cp /etc/vsftpd/vsftpd.conf.bak /etc/vsftpd/user_conf/user1
vim !$
----------------------------------
#    定义测试用户的FTP家目录
local_root=/opt/vsftpd/user1   
----------------------------------
# 这里将原vsftpd.conf配置文件经过简化后保存作为虚拟用户配置文件的模版。这里将并不需要指定
太多的配置内容,主要的框架和限制交由 Vsftpd的主配置文件vsftpd.conf来定义,即虚拟用户配置文
件当中没有提到的配置项目将参考主配置文件中的设定。而在这里作为虚拟用户的配置文件模版只需要
留一些和用户流量控制,访问方式控制的配置项目就可以了。这里的关键项是local_root这个配置,
用来指定这个虚拟用户的FTP主路径。

9. 更改虚拟用户的家目录权限

chown -R peng:peng /opt/vsftpd/

10. 启动服务

service vsftpd start

错误:

如果使用lftp遇到500错误,可能你的vsftpd.conf有不能被识别的命令,还有一种可能是命令的YES 或 NO 后面有空格,可使用cat -E vsftpd.conf检查


具体vsftpd.conf详细参数配置可见此贴:http://yuanbin.blog.51cto.com/363003/108262/

相关文章
|
6天前
|
存储 分布式计算 Hadoop
Centos7.9安装kerberos
Centos7.9安装kerberos
55 25
|
1天前
|
存储 Shell 网络安全
Centos7.9安装openldap
Centos7.9安装openldap
33 16
|
2天前
|
数据可视化 Linux 应用服务中间件
Centos7.9安装phpldapadmin
Centos7.9安装phpldapadmin
33 15
|
7天前
|
Java
CentOS7.8配置Adoptium-Java17运行环境
本指南介绍如何设置清华镜像源并安装 Temurin-17-JRE 运行环境。首先,编辑 `/etc/yum.repos.d/adoptium.repo` 文件,配置清华镜像源。接着,使用 `yum install -y temurin-17-jre` 命令安装 Temurin-17-JRE,并通过 `java --version` 验证安装成功。相关配置和操作界面截图附后。
22 8
|
5天前
|
网络协议 Java 应用服务中间件
centos7环境下tomcat8的安装与配置
本文介绍了在Linux环境下安装和配置Tomcat 8的详细步骤。首先,通过无网络条件下的文件交互软件(如Xftp 6或MobaXterm)下载并解压Tomcat安装包至指定路径,启动Tomcat服务并测试访问。接着,修改Tomcat端口号以避免冲突,并部署Java Web应用项目至Tomcat服务器。最后,调整Linux防火墙规则,确保外部可以正常访问部署的应用。关键步骤包括关闭或配置防火墙、添加必要的端口规则,确保Tomcat服务稳定运行。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
116 4
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
141 1
|
3月前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
145 1
Linux系统之Centos7安装cockpit图形管理界面
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
163 3