百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

FTP服务器使用虚拟用户更安全!CentOS Linux的配置教程看这里

bigegpt 2024-09-12 11:15 6 浏览

请关注本头条号,每天坚持更新原创干货技术文章。

如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习

1. 前言

本文主要是讲解与演示如何在Linux上配置vsftp 虚拟多用户。虚拟用户不能是系统用户,也不可能用于登录系统,只能用于ftp用户验证,所以对操作系统本身并无安全威胁问题。

2. 安装vsftpd

[root@zcwyou ~]# yum -y install vsftpd

安装vsftpd

3. 设置与vsftp相关的SElinux策略

设置ftp用户拥有所有权限

[root@zcwyou ~]# setsebool -P allow_ftpd_full_access=1
[root@zcwyou ~]# setsebool -P allow_ftpd_anon_write=1

4. 设置防火墙

4.1 CentOS 6防火墙设置

允许20、21端口通过防火墙

[root@zcwyou ~]# iptables -A INPUT -p tcp --dport 20:21 -j ACCEPT

设置ftp被动模式的端口范围

[root@zcwyou ~]# iptables -A INPUT -p tcp --dport 9000:9045 -j ACCEPT

保存防火墙配置:

[root@zcwyou ~]# service iptables save

4.2 CentOS 7防火墙设置

[root@zcwyou ~]# firewall-cmd --add-service=ftp
[root@zcwyou ~]# firewall-cmd --add-service=ftp --permanent

4.3 CentOS 6 设置开机自启动服务

[root@zcwyou ~]# chkconfig vsftpd on

4.4 CentOS 7 设置开机自启动服务

[root@zcwyou ~]# systemctl enable vsftpd

Created symlink from /etc/systemd/system/multi-user.target.wants/vsftpd.service to /usr/lib/systemd/system/vsftpd.service.

5. 配置vsftp虚拟用户

所谓虚拟用户就是没有使用真实的帐户,只是通过映射到真实帐户和设置权限的目的。虚拟用户不能登录CentOS系统。

修改配置文件

[root@zcwyou ~]# vi /etc/vsftpd/vsftpd.conf

配置vsftp虚拟用户

配置以下内容:

设定不允许匿名访问,即使用账号密码登录

anonymous_enable=NO

设定本地用户可以访问。注:如使用虚拟宿主用户,在该项目设定为NO的情况下所有虚拟用户将无法访问

local_enable=YES
write_enable=YES

允许匿名用户和虚拟用户写文件和目录

anon_upload_enable=YES
anon_mkdir_write_enable=YES
chroot_local_user=YES
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list

指定PAM认证文件名

pam_service_name=vsftpd

以下这些是关于vsftpd虚拟用户支持的重要配置项,默认vsftpd.conf中不包含这些设定项目,需要自己手动添加

设定启用虚拟用户功能

userlist_enable=YES
guest_enable=YES

指定虚拟用户的宿主用户,CentOS中已经有内置的ftp用户了

guest_username=ftp

设定虚拟用户个人vsftp的CentOS FTP服务文件存放路径。

user_config_dir=/etc/vsftpd/vuser_conf

创建chroot用户名单:

[root@zcwyou ~]# vi /etc/vsftpd/chroot_list

把虚拟用户写入这个文件,一行一个用户

test

6. 安装Berkeley DB工具

安装db4和db4-utils工具需要先安装epel仓库。用于建立用户数据库信息

[root@zcwyou ~]# yum install epel-release -y
[root@zcwyou ~]# yum install db4 db4-utils -y

安装Berkeley DB工具

7. 创建用户密码文本

创建文件/etc/vsftpd/vuser_passwd.txt ,注意奇行是用户名,偶行是密码

[root@zcwyou ~]# vi /etc/vsftpd/vuser_passwd.txt

例如,建立test账号,密码为123456,输入以下内容

test

123456

8. 生成虚拟用户认证的数据库文件

[root@zcwyou ~]# db_load -T -t hash -f /etc/vsftpd/vuser_passwd.txt /etc/vsftpd/vuser_passwd.db

9. 修改pam认证参数

随后,编辑认证文件/etc/pam.d/vsftpd,全部注释掉原来语句,再增加以下两句:

[root@zcwyou ~]# vi /etc/pam.d/vsftpd

不需要添加db后缀名

auth required pam_userdb.so db=/etc/vsftpd/vuser_passwd
account required pam_userdb.so db=/etc/vsftpd/vuser_passwd

10. 创建虚拟用户配置文件

最后,创建虚拟用户配置文件,文件名等于vuser_passwd.txt里面的账户名,否则下面设置无效

[root@zcwyou ~]# mkdir /etc/vsftpd/vuser_conf/
[root@zcwyou ~]# vi /etc/vsftpd/vuser_conf/test

内容如下:

虚拟用户根目录,根据实际情况修改

local_root=/data/ftp/test

可写权限及文件掩码

write_enable=YES
anon_umask=022
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=NO

创建test用户根目录及设置权限

[root@zcwyou ~]# mkdir -p /data/ftp/test/test_data
[root@zcwyou ~]# chmod -R 755 /data/
[root@zcwyou ~]# chmod 555 /data/ftp/test/
[root@zcwyou ~]# chown -R ftp:ftp /data/

最新的vsftpd要求对主目录不能有写的权限所以data为755,主目录下面的子目录再设置755权限或者你想要的权限。这样,test用户就可以对/data/ftp/test/test_data这个目录进行读写操作了。

11. 配置vsftp PASV模式(可选)

vsftpd默认没有开启PASV模式,现在FTP只能通过PORT模式连接,要开启PASV默认需要通过下面的配置

打开/etc/vsftpd/vsftpd.conf,在末尾添加

[root@zcwyou ~]# vi /etc/vsftpd/vsftpd.conf

开启PASV模式

pasv_enable=YES

最小端口号

pasv_min_port=40000

最大端口号

pasv_max_port=40080
pasv_promiscuous=YES

配置vsftp PASV模式

在防火墙配置内开启40000到40080端口

CentOS 6防火墙设置:

[root@zcwyou ~]# iptables -A INPUT -p tcp --dport 4000:40080 -j ACCEPT

CentOS 6重启防火墙:

[root@zcwyou ~]# service iptables save
[root@zcwyou ~]# service iptables restart

CentOS 7防火墙设置:

[root@zcwyou ~]# firewall-cmd --add-service=ftp
[root@zcwyou ~]# firewall-cmd --add-service=ftp --permanent

CentOS 6重启vsftpd:

[root@zcwyou ~]# service vsftpd restart

CentOS 7重启vsftpd:

[root@zcwyou ~]# systemctl restart vsftpd

12. 总结

vsftp是一个使用率非常高的服务,运维人员必须要熟悉配置和使用。

本文已同步至博客站,尊重原创,转载时请在正文中附带以下链接:

https://www.linuxrumen.com/rmxx/757.html

点击了解更多,快速查看更多的技术文章列表。

相关推荐

得物可观测平台架构升级:基于GreptimeDB的全新监控体系实践

一、摘要在前端可观测分析场景中,需要实时观测并处理多地、多环境的运行情况,以保障Web应用和移动端的可用性与性能。传统方案往往依赖代理Agent→消息队列→流计算引擎→OLAP存储...

warm-flow新春版:网关直连和流程图重构

本期主要解决了网关直连和流程图重构,可以自此之后可支持各种复杂的网关混合、多网关直连使用。-新增Ruoyi-Vue-Plus优秀开源集成案例更新日志[feat]导入、导出和保存等新增json格式支持...

扣子空间体验报告

在数字化时代,智能工具的应用正不断拓展到我们工作和生活的各个角落。从任务规划到项目执行,再到任务管理,作者深入探讨了这款工具在不同场景下的表现和潜力。通过具体的应用实例,文章展示了扣子空间如何帮助用户...

spider-flow:开源的可视化方式定义爬虫方案

spider-flow简介spider-flow是一个爬虫平台,以可视化推拽方式定义爬取流程,无需代码即可实现一个爬虫服务。spider-flow特性支持css选择器、正则提取支持JSON/XML格式...

solon-flow 你好世界!

solon-flow是一个基础级的流处理引擎(可用于业务规则、决策处理、计算编排、流程审批等......)。提供有“开放式”驱动定制支持,像jdbc有mysql或pgsql等驱动,可...

新一代开源爬虫平台:SpiderFlow

SpiderFlow:新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。-精选真开源,释放新价值。概览Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台,它使用Ja...

通过 SQL 训练机器学习模型的引擎

关注薪资待遇的同学应该知道,机器学习相关的岗位工资普遍偏高啊。同时随着各种通用机器学习框架的出现,机器学习的门槛也在逐渐降低,训练一个简单的机器学习模型变得不那么难。但是不得不承认对于一些数据相关的工...

鼠须管输入法rime for Mac

鼠须管输入法forMac是一款十分新颖的跨平台输入法软件,全名是中州韵输入法引擎,鼠须管输入法mac版不仅仅是一个输入法,而是一个输入法算法框架。Rime的基础架构十分精良,一套算法支持了拼音、...

Go语言 1.20 版本正式发布:新版详细介绍

Go1.20简介最新的Go版本1.20在Go1.19发布六个月后发布。它的大部分更改都在工具链、运行时和库的实现中。一如既往,该版本保持了Go1的兼容性承诺。我们期望几乎所...

iOS 10平台SpriteKit新特性之Tile Maps(上)

简介苹果公司在WWDC2016大会上向人们展示了一大批新的好东西。其中之一就是SpriteKitTileEditor。这款工具易于上手,而且看起来速度特别快。在本教程中,你将了解关于TileE...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Telerik UI for iOS Q3 2015正式发布

近日,TelerikUIforiOS正式发布了Q32015。新版本新增对XCode7、Swift2.0和iOS9的支持,同时还新增了对数轴、不连续的日期时间轴等;改进TKDataPoin...

ios使用ijkplayer+nginx进行视频直播

上两节,我们讲到使用nginx和ngixn的rtmp模块搭建直播的服务器,接着我们讲解了在Android使用ijkplayer来作为我们的视频直播播放器,整个过程中,需要注意的就是ijlplayer编...

IOS技术分享|iOS快速生成开发文档(一)

前言对于开发人员而言,文档的作用不言而喻。文档不仅可以提高软件开发效率,还能便于以后的软件开发、使用和维护。本文主要讲述Objective-C快速生成开发文档工具appledoc。简介apple...

macOS下配置VS Code C++开发环境

本文介绍在苹果macOS操作系统下,配置VisualStudioCode的C/C++开发环境的过程,本环境使用Clang/LLVM编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...