Proftpd和MySQL的虚拟主机(包括配额)

这是一个“复制和粘贴” HowTo! 遵循本教程的最简单的方法是使用命令行客户端/ SSH客户端(如PuTTY for Windows),并简单地复制和粘贴命令(除了必须提供自己的信息,如IP地址,主机名,密码... )。 这有助于避免打字错误。

使用Proftpd和MySQL虚拟托管(包括配额)

版本1.0
作者:Falko Timme

本文档介绍如何安装使用MySQL数据库而不是真实系统用户的虚拟用户的Proftpd服务器。 这是更好的性能,并允许在单个机器上有成千上万的ftp用户。 除此之外,我将使用此设置显示使用配额

对于MySQL数据库的管理,您可以使用基于Web的工具,如phpMyAdmin ,它也将安装在此howto中。 phpMyAdmin是一个舒适的图形界面,这意味着您不必乱用命令行。

本教程基于Debian Sarge (Debian 3.1)。 您应该已经设置了一个基本的Debian系统,如下所述: http : //www.youcl.com/perfect_setup_debian_sarge和 。 它应该适用于其他基于Debian的发行版,如UbuntuKnoppix等,无需修改。 在其他发行 ,如SuSEFedoraMandriva等,只有Proftpd安装是不同的; Proftpd的配置也应该适用于这些分发。

这是一个实践指南; 它不包括理论背景。 他们在网络上的许多其他文档中被处理。

本文档不附带任何形式的保证! 我想说,这不是设立这样一个制度的唯一办法。 实现这一目标有很多方法,但这是我所采取的方式。 我不会保证这将为您工作!

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安装Proftpd与MySQL支持

对于Debian,有一个预配置的proftpd-mysql包可用。 将其作为独立守护进程安装,如下所示:

apt-get install proftpd-mysql

从inetd或独立运行proftpd? < - 独立

然后我们创建一个ftp组(“ ftpgroup ”)和用户(“ ftpuser ”),我们所有的虚拟用户将被映射到。 将group-and userid 2001替换为系统上免费的数字:

groupadd -g 2001 ftpgroup
useradd -u 2001 -s / bin / false -d / bin / null -c“proftpd user”-g ftpgroup ftpuser

3为Proftpd创建MySQL数据库

现在我们创建一个名为ftp的数据库和名为proftpd的MySQL用户,proftpd守护程序稍后将使用它来连接到ftp数据库:

mysql -u root -p
创建数据库ftp;
GRANT SELECT,INSERT,UPDATE,DELETE ON ftp。* TO'proftpd'@'localhost'IDENTIFIED BY'password';
GRANT SELECT,INSERT,UPDATE,DELETE ON ftp。* TO'proftpd'@'localhost.localdomain'识别为'密码';
FLUSH特权

将字符串密码替换为要用于MySQL用户proftpd的任何密码。 仍然在MySQL shell上,我们创建了我们需要的数据库表:

USE ftp;

CREATE TABLE ftpgroup(
groupname varchar(16)NOT NULL default'',
gid smallint(6)NOT NULL default'5500',
成员varchar(16)NOT NULL default'',
KEY组名(组名)
)TYPE = MyISAM COMMENT ='ProFTP group table';

CREATE TABLE ftpquotalimits(
name varchar(30)default NULL,
quota_type枚举('user','group','class','all')NOT NULL default'user'
per_session enum('false','true')NOT NULL default'false'
limit_type枚举('soft','hard')NOT NULL默认'soft',
bytes_in_avail int(10)unsigned NOT NULL default'0',
byte_out_avail int(10)unsigned NOT NULL默认'0',
bytes_xfer_avail int(10)unsigned NOT NULL default'0',
file_in_avail int(10)unsigned NOT NULL默认'0',
file_out_avail int(10)unsigned NOT NULL默认'0',
file_xfer_avail int(10)unsigned NOT NULL默认'0'
)TYPE = MyISAM;

CREATE TABLE ftpquotatallies(
name varchar(30)NOT NULL default'',
quota_type枚举('user','group','class','all')NOT NULL default'user'
bytes_in_used int(10)unsigned NOT NULL default'0',
bytes_out_used int(10)unsigned NOT NULL默认'0',
bytes_xfer_used int(10)unsigned NOT NULL默认'0',
files_in_used int(10)unsigned NOT NULL默认'0',
files_out_used int(10)unsigned NOT NULL default'0'
files_xfer_used int(10)unsigned NOT NULL默认'0'
)TYPE = MyISAM;

CREATE TABLE ftpuser(
id int(10)unsigned NOT NULL auto_increment,
userid varchar(32)NOT NULL default'',
passwd varchar(32)NOT NULL default'',
uid smallint(6)NOT NULL default'5500',
gid smallint(6)NOT NULL default'5500',
homedir varchar(255)NOT NULL default'',
shell varchar(16)NOT NULL default'/ sbin / nologin',
count int(11)NOT NULL default'0',
访问datetime NOT NULL默认'0000-00-00 00:00:00',
修改datetime NOT NULL默认'0000-00-00 00:00:00',
PRIMARY KEY(id),
UNIQUE KEY userid(userid)
)TYPE = MyISAM COMMENT ='ProFTP用户表';

放弃;

你可能已经注意到,随着戒烟; 命令我们已经离开了MySQL shell,并回到了Linux shell。

BTW,(我建议您的ftp服务器系统的主机名为server1.example.com ),您可以通过http://server1.example.com/phpmyadmin/访问phpMyAdmin (您可以使用IP地址而不是server1。 example.com ),并以proftpd身份登录。 那么你可以看看数据库。 以后可以使用phpMyAdmin管理您的Proftpd服务器。

赞(52) 打赏
未经允许不得转载:优客志 » 系统运维
分享到:

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏