使用PureFTPd和MySQL虚拟主机(包括配额和带宽管理)
版本1.0
作者:Falko Timme
本文档介绍如何安装使用MySQL数据库而不是真实系统用户的虚拟用户的PureFTPd服务器。 这是更好的性能,并允许在单个机器上有成千上万的ftp用户。 除此之外,我将使用此设置显示使用配额和上传/下载带宽限制 。 密码将作为MD5字符串加密存储在数据库中。
对于MySQL数据库的管理,您可以使用基于Web的工具,如phpMyAdmin ,它也将安装在此howto中。 phpMyAdmin是一个舒适的图形界面,这意味着您不必乱用命令行。
本教程基于Debian Sarge (Debian 3.1)。 您应该已经设置了一个基本的Debian系统,如下所述: http : //www.youcl.com/perfect_setup_debian_sarge和 。 它应该适用于其他基于Debian的发行版,如Ubuntu , Knoppix等,无需修改。 在SuSE , Fedora , Mandriva等其他发行版上 ,只有PureFTPd安装是不同的; PureFTPd的配置也适用于这些分发。
这是一个实践指南; 它不包括理论背景。 他们在网络上的许多其他文档中被处理。
本文档不附带任何形式的保证! 我想说,这不是设立这样一个制度的唯一办法。 实现这一目标有很多方法,但这是我所采取的方式。 我不会保证这将为您工作!
1安装MySQL和phpMyAdmin
这一切都可以通过一个命令安装:
apt-get install mysql-server mysql-client libmysqlclient12-dev phpmyadmin
你会被问到几个问题:
启用suExec? < - 是的
配置mysql-server(安装提示)< - OK
您要自动重新配置哪个Web服务器? < - apache,apache2
你要我现在重新启动apache吗? < - 是的
为MySQL用户 root 创建密码 (将 yourrootsql 密码 替换 为您要使用的密码):
mysqladmin -u root password yourrootsqlpassword
2使用MySQL支持安装PureFTPd
对于Debian,有一个预配置的纯ftpd-mysql包可用。 将其作为独立守护进程安装,如下所示:
apt-get install pure-ftpd-mysql
从inetd或独立服务器运行纯ftpd? < - 独立
你想要纯ftpwho安装setuid root吗? < - 不
然后我们创建一个ftp组(“ ftpgroup ”)和用户(“ ftpuser ”),我们所有的虚拟用户将被映射到。 将group-and userid 2001替换为系统上免费的数字:
groupadd -g 2001 ftpgroup
useradd -u 2001 -s / bin / false -d / bin / null -c“pureftpd user”-g ftpgroup ftpuser
3为PureFTPd创建MySQL数据库
现在我们创建一个名为pureftpd的数据库和名为pureftpd的MySQL用户,PureFTPd后台程序稍后将使用它连接到pureftpd数据库:
mysql -u root -p
CREATE DATABASE pureftpd;
GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP ON pureftpd。* TO'pureftpd'@'localhost'IDENTIFIED BY'ftpdpass';
GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP ON pureftpd。* TO'pureftpd'@'localhost.localdomain'标识为'ftpdpass';
FLUSH特权
将字符串ftpdpass替换为您要用于MySQL用户pureftpd的任何密码。 仍然在MySQL shell上,我们创建了我们需要的数据库表(是的,只有一个表!):
USE pureftpd;
CREATE TABLE ftpd
用户varchar(16)NOT NULL default'',
状态枚举('0','1')NOT NULL默认'0',
密码varchar(64)NOT NULL default'',
Uid varchar(11)NOT NULL default'-1'
Gid varchar(11)NOT NULL默认'-1',
Dir varchar(128)NOT NULL default'',
ULBandwidth smallint(5)NOT NULL default'0',
DLBandwidth smallint(5)NOT NULL default'0',
评论tinytext NOT NULL,
ipaccess varchar(15)NOT NULL default'*',
QuotaSize smallint(5)NOT NULL默认'0',
QuotaFiles int(11)NOT NULL default 0,
主键(用户),
独特的用户(用户)
)TYPE = MyISAM;
放弃;
你可能已经注意到,随着戒烟; 命令我们已经离开了MySQL shell,并回到了Linux shell。
BTW,(我建议您的ftp服务器系统的主机名为server1.example.com ),您可以通过http://server1.example.com/phpmyadmin/访问phpMyAdmin (您也可以使用IP地址而不是server1 .example.com ),并以pureftpd身份登录。 那么你可以看看数据库。 以后可以使用phpMyAdmin管理您的PureFTPd服务器。