配置虚拟用户FTP
上面配置的FTP服务器有一个特点,就是FTP服务器的用户本身也是系统用户。这显然是一个安全隐患,因为这些用户不仅能够访问FTP,也能够访问其它的系统资源。如何解决这个问题呢?答案就是创建一个虚拟用户的FTP服务器。虚拟用户的特点是只能访问服务器为其提供的FTP服务,而不能访问系统的其它资源。所以,如果想让用户对FTP服务器站内具有写权限,但又不允许访问系统其它资源,可以使用虚拟用户来提高系统的安全性。
在VSFTP中,认证这些虚拟用户使用的是单独的口令库文件(pam_userdb),由可插入认证模块(PAM)认证。使用这种方式更加安全,并且配置更加灵活。
下面介绍配置过程。
1.生成虚拟用户口令库文件。为了建立此口令库文件,先要生成一个文本文件。该文件的格式如下,单数行为用户名,偶数行为口令:
引用
#vi account.txt
user01
1234
user02
4321
2.生成口令库文件,并修改其权限: (确保机器安装了db4,db4-devel)
引用
#db_load -T -t hash -f ./account.txt /etc/vsftpd/account.db
#chmod 600 /etc/vsftpd/account.db
3.新建一个虚拟用户的PAM文件。加上如下两行内容:
引用
#vi /etc/pam.d/vsftp.vu
auth required /lib64/security/pam_userdb.so db=/etc/vsftpd/account
account required /lib64/security/pam_userdb.so db=/etc/vsftpd/account
4.建立虚拟用户,设置该用户所要访问的目录,并设置虚拟用户访问的权限:
引用
#useradd -d /home/ftpsite virtual_user
#chmod 700 /home/ftpsite
经过该步骤的设置,/home/ftpsite就是virtual_user用户的主目录,该用户也是/home/ftpsite目录的拥有者。除root用户之外,只有该用户具有对该目录的读、写和执行的权限。
5.生成一个测试文件。先切换至virtual_user用户身份,然后在/ftpsite目录下创建一个文件:
引用
#su -virtual_user
$vi /home/ftpsite/mytest
This is a test file.
$su - root
6.编辑/etc/vsftpd/vsftpd.conf文件,使其整个文件内容如下所示(去掉了注释内容):
引用
anonymous_enable=NO
local_enable=YES
local_umask=022
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=YES
listen=YES
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
one_process_model=NO
chroot_local_user=YES
ftpd_banner=Welcom to my FTP server.
anon_world_readable_only=NO
guest_enable=YES
guest_username=virtual_user
pam_service_name=vsftp.vu
上面代码中,guest_enable=YES表示启用虚拟用户;guest_username=virtual则是将虚拟用户映射为本地用户,这样虚拟用户登录后才能进入本地用户virtual的目录/ftpsite;pam_service_name=vsftp.vu指定PAM的配置文件为 vsftp.vu。
为每个虚拟用户指定默认路径:
vsftpd.conf中加入
user_config_dir=/etc/vsftpd/vsftpd_user_config
user_sub_token=$USER
/etc/vsftpd/vsftpd_user_config目录下为每个用户建一个设置文件,文件名和用户名相同,内容中必须有
local_root=/home/ftp/$USER
在/home/ftpsite/下面为每个用户创建文件夹
7.重新启动VSFTP:
#service vsftpd restart
8.以虚拟用户gou(Linux中并无该账号)进行测试:
引用
# ftp 127.0.0.1
Connected to 127.0.0.1 (127.0.0.1).
220 Welcom to my FTP server.
Name (127.0.0.1:root): gou
331 Please specify the password.
Password:
230 Login successful. Have fun.
Remote system type is UNIX.
Using binary mode to transfer files.
local_root=/var/ftp/share
download_enable=yes
anon_upload_enable=no
anon_other_write_enable=no
anon_mkdir_write_enable=yes
anon_world_readable_only=no
file_open_mode=0777
anon_umask=0333修改上传文件的属性
cannot change directory:/home/***
ftp服务器连接失败,错误提示:
500 OOPS: cannot change directory:/home/*******
500 OOPS: child died
解决方法:
在终端输入命令:
setsebool<wbr><wbr>ftpd_disable_trans<wbr><wbr>1</wbr></wbr></wbr></wbr>
service<wbr><wbr>vsftpd<wbr><wbr>restart</wbr></wbr></wbr></wbr>
就OK了!
<wbr><wbr></wbr></wbr>
在安装完vsftp服务后登陆时可能遇到cannot change directory后面是登陆者的目录的错误。这是因为SE设置的关闭了ftp的原因。 使用命令 getsebool ftpd_disable_trans 可以查看当前的状态如果不是on 那么是输入命令 setsebool ftpd_disable_trans 1 当然也可以加入-P参数 以便不需要每次开机都输入这个命令 setsebool -P ftpd_disable_trans 1 同理
如果smb服务也遇到相同的问题
在安装完vsftp服务后登陆时可能遇到cannot change directory后面是登陆者的目录的错误。这是因为SE设置的关闭了ftp的原因。
使用命令
getsebool ftpd_disable_trans
可以查看当前的状态如果不是on
那么是输入命令
setsebool ftpd_disable_trans 1
当然也可以加入-P参数 以便不需要每次开机都输入这个命令
setsebool -P ftpd_disable_trans 1
同理 如果smb服务也遇到相同的问题 ,也可以这么做。
setsebool -P samba_enable_home_dirs=1
selinux的问题也可以使用 管理工具中的 selinux management 来调整相关设置。
分享到:
相关推荐
本教程将详细阐述如何在CentOS7环境中配置VSFTP,使得虚拟用户能够安全地访问FTP服务。这个过程涉及到几个关键步骤,包括安装VSFTPD、创建和配置虚拟用户、以及设置权限。 首先,我们需要安装VSFTPD。在CentOS7中,...
本篇文章将详细介绍如何配置VSFTP的虚拟用户。 一、安装VSFTP 在大多数Linux发行版中,你可以通过包管理器来安装VSFTP。例如,在Ubuntu或Debian上,使用以下命令: ```bash sudo apt-get update sudo apt-get ...
### Centos7下安装vsftpd并启用虚拟用户访问 #### 一、环境搭建与软件安装 在CentOS 7环境中部署vsftpd并实现虚拟用户登录,首先需要完成vsftpd服务的基本安装。 1. **安装vsftpd及其客户端**: ```bash yum ...
在 CentOS 6.3 系统上安装与配置 vsftp 服务是一项常见的任务,主要用于搭建 FTP 服务器,以便用户能够通过 FTP 协议上传或下载文件。vsftp 是一个非常强大的 FTP 服务器程序,它不仅稳定可靠,而且支持多种认证方式...
在本文中,我们将详细介绍如何在Linux系统中部署VSFTP,包括匿名用户、系统用户和虚拟用户的配置。 首先,为了确保VSFTP能够顺利运行,我们需要关闭防火墙并安装必要的服务。可以通过执行以下命令关闭SELinux和...
,通过执行install.sh脚本,脚本会根据参数区域的值执行安装和配置vsftp服务,安装后会创建一个默认ftp用户wangxf密码wangxf@2023 1、支持自定义安装(更改脚本内参数值) 2、支持快速创建ftp虚拟用户,每个用户间相互...
4. 修改 vsftpd 配置:启用虚拟用户模式(`virtual_use_local_users=YES`),配置 pam 模块认证。 5. 权限设定:为虚拟用户指定家目录和文件权限,如 `chown vuser:vuser /home/vuser` 并设置 `chmod 755 /home/...
下面我们将详细讲解如何在Linux环境中安装并配置VSFTP。 首先,我们需要通过包管理器安装必要的组件。在这个例子中,我们使用的是`yum`命令,它适用于基于RPM的系统如CentOS或Fedora。运行以下命令来安装VSFTP及其...
本文将深入探讨Vsftp的安装过程、虚拟用户设置以及配置细节。 首先,我们来详细讲解Vsftp的安装步骤。在大多数Linux发行版中,可以通过包管理器进行安装。以Ubuntu或Debian为例,你可以使用`apt-get`命令: ```...
在CentOS 5和6这样的系统上配置Vsftp,可以确保系统的安全性和稳定性。以下是详细的配置步骤: 1. **相关部件安装** 首先,需要安装Vsftp服务的软件包`Vsftpd-xxx-xxx.rpm`和用于数据库管理的`db4-utils-xxx.rpm`...
- **虚拟用户和组**:配置虚拟用户需要结合PAM和口令文件,涉及多个步骤,包括创建口令文件、配置PAM服务和vsftpd.conf。 **3. VSFTP服务器的维护** - **日志功能**:`xferlog_enable=YES`开启日志记录,`xferlog_...
但有时我们只想提供ftp服务,而避免用户用ftp的帐号去登录linux,采用一般的方式只能是限制该用户的访问权限,但还是避免不了用户登录进linux系统,所以比较好的方法是用vsftpd的虚拟用户(virtual users)。...
### CentOS 7 上安装与卸载 vsftpd ...通过以上步骤,您就可以在 CentOS 7 上成功安装并配置 vsftpd 服务器了。这些配置项涵盖了 vsftpd 的基本功能,包括安全性和性能优化等方面,可以满足大多数应用场景的需求。
本指南将详细介绍如何在Linux系统上安装和配置VSFTP服务器,以便为用户提供安全的文件传输服务。 一、解压安装 VSFTP的安装通常通过包管理器进行,例如在Ubuntu或Debian上使用`apt-get`,在CentOS或Fedora上使用`...
**vsFTP服务器初步管理** vsFTP(Very Secure FTP)是一个高度可配置且广泛使用的FTP(File Transfer Protocol)...不断学习和探索,掌握更多高级功能,如虚拟用户、限速、用户隔离等,将使您成为更出色的系统管理员。
- 在`/etc/samba/smb.conf`配置文件中设置`security = user`,这表示只有经过验证的用户才能访问共享资源。 - **配置用户的共享:** - 配置文件中定义共享目录,并指定用户权限。 - **测试Windows和Linux之间...
三、配置VSFTP VSFTP的主要配置文件是`/etc/vsftpd/vsftpd.conf`。常用的配置选项包括: 1. `anonymous_enable=YES/NO`:启用或禁用匿名FTP。 2. `local_enable=YES/NO`:允许本地用户登录。 3. `write_enable=YES/...
根据题目中的描述,本案例是在CentOS Linux release 7.3.1611 (Core) 上进行VSFTPD的安装和配置。为了顺利完成安装,首先需要准备必要的环境。 - **操作系统版本**:CentOS Linux release 7.3.1611 (Core) - **日志...
在实际操作过程中,根据具体需求,可能还需要进行更复杂的设置,例如设置用户权限、创建虚拟用户、限制上传下载速度等。记得在修改配置文件后重启服务以应用更改。希望这篇指南对你在Linux环境下搭建FTP服务器有所...