Centos6.8:vsftpd安装与配置

本文涉及的产品
运维安全中心(堡垒机),免费版 6个月
日志服务 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/

相关文章
|
30天前
|
存储 安全 Linux
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
100 64
|
1月前
|
存储 安全 Linux
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
110 61
|
1天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
24天前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
53 1
Linux系统之Centos7安装cockpit图形管理界面
|
8天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
29 3
|
9天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
17 2
|
30天前
|
NoSQL 数据可视化 Linux
redis学习四、可视化操作工具链接 centos redis,付费Redis Desktop Manager和免费Another Redis DeskTop Manager下载、安装
本文介绍了Redis的两个可视化管理工具:付费的Redis Desktop Manager和免费的Another Redis DeskTop Manager,包括它们的下载、安装和使用方法,以及在使用Another Redis DeskTop Manager连接Redis时可能遇到的问题和解决方案。
101 1
redis学习四、可视化操作工具链接 centos redis,付费Redis Desktop Manager和免费Another Redis DeskTop Manager下载、安装
|
11天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
50 2
|
15天前
|
Linux 知识图谱
Centos7安装killall,fuser, killall,pstree和pstree.x11
通过上述步骤,您已在CentOS 7系统中成功部署了killall、fuser、pstree以及pstree.x11,为高效管理系统进程打下了坚实基础。更多关于服务器管理与优化的知识,获取全面技术支持与解决方案。
18 1
|
15天前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
31 1
下一篇
无影云桌面