linux pureftpd mysql_虚拟主机与PureFTPd和MySQL(包括配额和带宽管理)在CentOS 5.0

使用PureFTPd和MySQL虚拟主机(包括配额和带宽管理)在CentOS 5.0上

版本1.0

作者:Falko Timme

本文档介绍如何安装使用MySQL数据库而不是真实系统用户的虚拟用户的PureFTPd服务器。 这是更好的性能,并允许在单个机器上有成千上万的ftp用户。 除此之外,我将使用此设置显示使用配额和上传/下载带宽限制。 密码将作为MD5字符串加密存储在数据库中。

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

本教程基于CentOS 5.0。 您应该已经设置了基本的CentOS 5.0系统,例如本教程前四章所述: http : //www.howtoing.com/perfect_setup_centos5.0

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

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

1初步说明

在本教程中,我使用IP地址为192.168.0.100的hostname server1.example.com 。 这些设置可能会有所不同,因此您必须在适当的情况下更换它们。

2安装MySQL和Apache / PHP

我们可以使用单个命令安装MySQL和Apache / PHP(phpMyAdmin需要Apache和PHP):

yum install mysql mysql-server httpd php php-mysql php-mbstring

然后我们为MySQL和Apache创建系统启动链接(这样每当系统启动时都会自动启动)并启动这两个服务:

chkconfig --levels 235 mysqld on

/etc/init.d/mysqld start

chkconfig --levels 235 httpd on

/etc/init.d/httpd start

为MySQL用户root创建密码(将yourrootsql密码替换为您要使用的密码):

mysqladmin -u root password yourrootsqlpassword

mysqladmin -h server1.example.com -u root password yourrootsqlpassword

3安装phpMyAdmin

不幸的是,官方的CentOS 5.0存储库中没有phpMyAdmin软件包,但是在CentOS 5.0版本的centos.karan.org存储库中也找到了一个适用于CentOS 4.x的phpMyAdmin软件包 。 我们可以这样安装:

rpm -ivh http://centos.karan.org/el4/misc/testing/i386/RPMS/phpMyAdmin-2.7.0-3.el4.pl2.lsn.noarch.rpm

之后,您应该可以在浏览器中的这个地址下访问phpMyAdmin: http : //server1.example.com/phpMyAdmin/ (您也可以使用IP地址而不是server1.example.com )。

如果您发现您的phpMyAdmin缺少大量图像并且加载有问题,请打开文件/usr/share/phpMyAdmin/config.inc.php并注释掉$ cfg ['PmaAbsoluteUri']行:

vi /usr/share/phpMyAdmin/config.inc.php[...]

#$cfg['PmaAbsoluteUri'] = 'http://server1.example.com/phpMyAdmin/';

[...]

之后,phpMyAdmin应该按预期工作。

4使用MySQL支持安装PureFTPd

再次,官方CentOS 5.0存储库中没有PureFTPd软件包,但centos.karan.org存储库具有用于CentOS 5.0(在kbs-CentOS-Testing存储库中)的PureFTPd软件包。 因此,我们将这个存储库添加到我们官方的CentOS存储库中:

cd /etc/yum.repos.d/

wget http://centos.karan.org/kbsingh-CentOS-Extras.repo

现在我们必须启用kbs-CentOS-Testing存储库。 为此,我们打开文件kbsingh-CentOS-Extras.repo ,并在kbs-CentOS-Testing节中将 enabled = 0更改为enabled = 1 :

vi kbsingh-CentOS-Extras.repo[...]

[kbs-CentOS-Testing]

name=CentOS.Karan.Org-EL$releasever - Testing

gpgcheck=1

gpgkey=http://centos.karan.org/RPM-GPG-KEY-karan.org.txt

enabled=1

baseurl=http://centos.karan.org/el$releasever/extras/testing/$basearch/RPMS/

然后我们导入我们的新存储库的GPG密钥:

rpm --import http://centos.karan.org/RPM-GPG-KEY-karan.org.txt

现在我们可以安装PureFTPd:

yum install pure-ftpd

然后我们创建一个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

5为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' IDENTIFIED BY 'ftpdpass';

FLUSH PRIVILEGES;

将字符串ftpdpass替换为您要用于MySQL用户pureftpd的任何密码。 仍然在MySQL shell上,我们创建了我们需要的数据库表(是的,只有一个表!):

USE pureftpd;

CREATE TABLE ftpd (

User varchar(16) NOT NULL default '',

status enum('0','1') NOT NULL default '0',

Password varchar(64) NOT NULL default '',

Uid varchar(11) NOT NULL default '-1',

Gid varchar(11) NOT NULL default '-1',

Dir varchar(128) NOT NULL default '',

ULBandwidth smallint(5) NOT NULL default '0',

DLBandwidth smallint(5) NOT NULL default '0',

comment tinytext NOT NULL,

ipaccess varchar(15) NOT NULL default '*',

QuotaSize smallint(5) NOT NULL default '0',

QuotaFiles int(11) NOT NULL default 0,

PRIMARY KEY (User),

UNIQUE KEY User (User)

) TYPE=MyISAM;

quit;

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

BTW,(我假设您的ftp服务器系统的主机名为server1.example.com ),您可以访问http://server1.example.com/phpMyAdmin/下的phpMyAdmin (您也可以使用IP地址而不是server1 .example.com )在浏览器中以用户pureftpd身份登录。 那么你可以看看数据库。 以后可以使用phpMyAdmin管理您的PureFTPd服务器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值