UTF.COM.CN

Proftpd(MySQL+Quotas)

作者:佚名 | 来源:网络 | 添加时间:2006-03-07 12:38:34 | 人气:2881

Proftpd(MySQL+Quotas)(1)

1、什么是ProFTPD;ProFTPD 是一个FTP服务器程序,和vsftpd、wuftp 类似的FTP服务器,他们最终实现功能和目的都是一样的,都是为了传输文件;
2、ProFTPD的下载
proftpd-1.2.9.tar.gz
proftpd-mod-quotatab-1.2.11.tar.gz
(注意:如果你的mysql是自编译安装的,请先别忙着安装,请至本文最后,看完补充再装也不迟)

3、ProFTPD的编译和安装;
tar zvxf proftpd-1.2.9.tar.gz
tar zvxf proftpd-mod-quotatab-1.2.11.tar.gz
cp mod_quotatab/*.c proftpd-1.2.9/contrib/
cp mod_quotatab/*.h proftpd-1.2.9/contrib/
cd proftpd-1.2.9
./configure 
--prefix=/usr/local/proftpd 
--with-modules=mod_sql:mod_sql_mysql:mod_quotatab:mod_quotatab_sql:mod_ratio 
--with-includes=/usr/include/mysql 
--with-libraries=/usr/lib/mysql
make 
make install

说明:
--with-modules=mod_sql:mod_sql_mysql:mod_quotatab:mod_quotatab_sql 
这句是让编译ProFTPD 支持MySQL的模块,并有磁盘限额支持;
--with-includes= 
这是来指定MySQL服务器includes所在的位置;在这里我设置的是/usr/include/mysql,因为我的MySQL服务器的includes的确在这个目录;你可以根据自己的机器环境来调整;
--with-libraries=
这是来指定MySQL服务器libraries所在的位置;在这里我设置的是/usr/lib/mysql,因为我的MySQL服务器的libraries的确在这个目录;你可以根据自己的机器环境来调整;
--prefix= 
这是用来指定要把ProFTPD安装在哪个位置,在这里我把ProFTPD安装在了 /usr/local/proftpd 目录下,您不必自己建目录 /usr/local/proftpd ,在安装的时候这个目录会自动生成;当然您也可以自己来指定ProFTPD的安装位置;当我们不需要proftpd的时候,就可以直接删除proftpd目录;这样做好象是有点方便;

创建Proftpd启动脚本
cp contrib/dist/rpm/proftpd.init.d /etc/rc.d/init.d/proftpd
vi /etc/rc.d/init.d/proftpd
找到PATH="$PATH:/usr/local/sbin"这一句
将它改成PATH="$PATH:/usr/local/proftpd/sbin"
chmod 755 /etc/rc.d/init.d/proftpd

4.建立相应的用户和用户组
groupadd -g 5500 ftpgroup
adduser -u 5500 -s /bin/false -d /bin/null -c "proftpd user" -g ftpgroup ftpuser

5、ProFTPD认证中的MySQL数据库

QUOTE:
mysql -uroot -ppassword
create database ftpdb;
grant select, update on ftpdb.* to proftpd@localhost identified by ’password’;
use ftpdb;

CREATE TABLE `ftpgroup` (
`groupname` varchar(16) NOT NULL default ’’,
`gid` smallint(6) NOT NULL default ’5500’,
`members` varchar(16) NOT NULL default ’’,
KEY `groupname` (`groupname`)
) TYPE=MyISAM COMMENT=’ProFTP group table’;

INSERT INTO `ftpgroup` VALUES (’ftpgroup’, 5500, ’ftpuser’);

CREATE TABLE `ftpquotalimits` (
`name` varchar(30) default NULL,
`quota_type` enum(’user’,’group’,’class’,’all’) NOT NULL default ’user’,
`per_session` enum(’false’,’true’) NOT NULL default ’false’,
`limit_type` enum(’soft’,’hard’) NOT NULL default ’soft’,
`bytes_in_avail` float NOT NULL default ’0’,
`bytes_out_avail` float NOT NULL default ’0’,
`bytes_xfer_avail` float NOT NULL default ’0’,
`files_in_avail` int(10) unsigned NOT NULL default ’0’,
`files_out_avail` int(10) unsigned NOT NULL default ’0’,
`files_xfer_avail` int(10) unsigned NOT NULL default ’0’
) TYPE=MyISAM;

CREATE TABLE `ftpquotatallies` (
`name` varchar(30) NOT NULL default ’’,
`quota_type` enum(’user’,’group’,’class’,’all’) NOT NULL default ’user’,
`bytes_in_used` float NOT NULL default ’0’,
`bytes_out_used` float NOT NULL default ’0’,
`bytes_xfer_used` float NOT NULL default ’0’,
`files_in_used` int(10) unsigned NOT NULL default ’0’,
`files_out_used` int(10) unsigned NOT NULL default ’0’,
`files_xfer_used` int(10) unsigned NOT NULL default ’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’,
`host` varchar(30) NOT NULL default ’000-000-000-000’,
`lastlogin` datetime NOT NULL default ’0000-00-00 00:00:00’,
PRIMARY KEY (`id`)
) TYPE=MyISAM COMMENT=’ProFTP user table’;
责任编辑:冬天来了
【字号: 】【去论坛讨论】【发表评论】【打印本文】【告诉好友】【关闭窗口
网友评论(评论内容只代表网友观点,与本站立场无关!)

姓名:

验证码: 点击刷新