虚拟主机与vsftpd和MySQL在Debian Etch
版本1.0
作者:Falko Timme
Vsftpd是Linux最安全最快的FTP服务器之一。 通常,vsftpd配置为与系统用户一起工作。 本文档介绍如何安装使用MySQL数据库而不是真实系统用户的虚拟用户的vsftpd服务器。 这是更好的性能,并允许在单个机器上有成千上万的ftp用户。
对于MySQL数据库的管理,您可以使用基于Web的工具,如phpMyAdmin,它也将安装在此howto中。 phpMyAdmin是一个舒适的图形界面,这意味着您不必乱用命令行。
本教程基于Debian Etch(Debian 4.0)。 您应该已经建立了一个基本的Debian蚀刻系统,如本教程前六章所述: http : //www.youcl.com/perfect_setup_debian_etch
这是一个实践指南; 它不包括理论背景。 他们在网络上的许多其他文档中被处理。
本文档不附带任何形式的保证! 我想说,这不是设立这样一个制度的唯一办法。 实现这一目标有很多方法,但这是我所采取的方式。 我不会保证这将为您工作!
1初步说明
在本教程中,我使用IP地址为192.168.0.100
的hostname server1.example.com
。 这些设置可能会有所不同,因此您必须在适当的情况下更换它们。
2安装vsftpd,MySQL和phpMyAdmin
Vsftpd没有内置的MySQL支持,因此我们必须使用PAM对MySQL数据库进行身份验证。 所以我们安装libpam-mysql除了vsftpd,MySQL和phpMyAdmin之外:
apt-get install vsftpd libpam-mysql mysql-server mysql-client phpmyadmin
为MySQL用户root
创建密码(将yourrootsql
密码替换为您要使用的密码):
mysqladmin -u root password yourrootsqlpassword
然后检查
netstat -tap | grep mysql
MySQL正在监听哪个地址。 如果输出如下所示:
tcp 0 0 localhost.localdo:mysql *:* LISTEN 2713/mysqld
这意味着MySQL只监听localhost.localdomain
,那么你以前设置的密码是安全的。 但如果输出如下所示:
tcp 0 0 *:mysql *:* LISTEN 2713/mysqld
您也应该为您的主机名设置一个MySQL密码,因为否则任何人都可以访问您的数据库并修改数据:
mysqladmin -h server1.example.com -u root password yourrootsqlpassword
3创建vsftpd的MySQL数据库
现在我们创建一个名为vsftpd
的数据库和一个名为vsftpd
的MySQL用户,vsftpd守护程序稍后将使用它连接到vsftpd
数据库:
mysql -u root -p
CREATE DATABASE vsftpd;
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON vsftpd.* TO 'vsftpd'@'localhost' IDENTIFIED BY 'ftpdpass';
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON vsftpd.* TO 'vsftpd'@'localhost.localdomain' IDENTIFIED BY 'ftpdpass';
FLUSH PRIVILEGES;
用ftpdpass
替换您要用于MySQL用户vsftpd的
任何密码。 仍然在MySQL shell上,我们创建了我们需要的数据库表(是的,只有一个表!):
USE vsftpd;
CREATE TABLE `accounts` (
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`username` VARCHAR( 30 ) NOT NULL ,
`pass` VARCHAR( 50 ) NOT NULL ,
UNIQUE (
`username`
)
) ENGINE = MYISAM ;
quit;
你可能已经注意到,随着戒烟;
命令我们已经离开了MySQL shell,并回到了Linux shell。
BTW,(我假设您的ftp服务器系统的主机名是server1.example.com
),您可以访问http://server1.example.com/phpmyadmin/下的phpMyAdmin
(您也可以使用IP地址而不是server1 .example.com
),并以用户vsftpd
身份登录。 那么你可以看看数据库。 以后可以使用phpMyAdmin来管理vsftpd服务器。