proftpd ,基于mysql磁盘配额使用比较失望。
基于mysql 验证 proftpd 安装成功。
测试发现proftpd跟SERV-U一样,无法计算实际FTP文件大小且性能上也不是很好,因为客户端每个操作都要查询或修改MYSQL数据行。

 proftpd.conf
proftpd.conf # This is a basic ProFTPD configuration file (rename it to
# This is a basic ProFTPD configuration file (rename it to # 'proftpd.conf' for actual use.  It establishes a single server
# 'proftpd.conf' for actual use.  It establishes a single server # and a single anonymous login.  It assumes that you have a user/group
# and a single anonymous login.  It assumes that you have a user/group # "nobody" and "ftp" for normal operation and anon.
# "nobody" and "ftp" for normal operation and anon.
 ServerName                      "ProFTPD Default Installation"
ServerName                      "ProFTPD Default Installation" ServerType                      standalone
ServerType                      standalone DefaultServer                   on
DefaultServer                   on
 # Port 21 is the standard FTP port.
# Port 21 is the standard FTP port. Port                            21
Port                            21
 # Umask 022 is a good standard umask to prevent new dirs and files
# Umask 022 is a good standard umask to prevent new dirs and files # from being group and world writable.
# from being group and world writable. Umask                           022
Umask                           022
 # To prevent DoS attacks, set the maximum number of child processes
# To prevent DoS attacks, set the maximum number of child processes # to 30.  If you need to allow more than 30 concurrent connections
# to 30.  If you need to allow more than 30 concurrent connections # at once, simply increase this value.  Note that this ONLY works
# at once, simply increase this value.  Note that this ONLY works # in standalone mode, in inetd mode you should use an inetd server
# in standalone mode, in inetd mode you should use an inetd server # that allows you to limit maximum number of processes per service
# that allows you to limit maximum number of processes per service # (such as xinetd).
# (such as xinetd). MaxInstances                    30
MaxInstances                    30
 # Set the user and group under which the server will run.
# Set the user and group under which the server will run. #User                           nobody
#User                           nobody #Group                          nobody
#Group                          nobody
 User                           ftpUser
User                           ftpUser Group                          ftpGroup
Group                          ftpGroup





 # 最大的用户数
# 最大的用户数 #MaxClients      100
#MaxClients      100 #MaxHostsPerUser 1
#MaxHostsPerUser 1 #MaxClientsPerUser 2
#MaxClientsPerUser 2 # 对不起,一个IP只允许一个连接
# 对不起,一个IP只允许一个连接 #MaxClientsPerHost 1
#MaxClientsPerHost 1
 #RootLogin off
#RootLogin off RequireValidShell off
RequireValidShell off #UseReverseDNS     off
#UseReverseDNS     off #IdentLookups      off
#IdentLookups      off #TimeoutStalled    600
#TimeoutStalled    600 #TimeoutLogin      900
#TimeoutLogin      900 #TimeoutIdle       600
#TimeoutIdle       600 #TimeoutNoTransfer 600
#TimeoutNoTransfer 600 # 让proftp支持现在流行的FXP传输方式,默认是不支持的
# 让proftp支持现在流行的FXP传输方式,默认是不支持的 #AllowForeignAddress on
#AllowForeignAddress on
 # 屏蔽服务器版本信息
# 屏蔽服务器版本信息 #ServerIdent off
#ServerIdent off


 UseReverseDNS off
UseReverseDNS off IdentLookups off
IdentLookups off


 ######################## 下面是磁盘限额Quota设置 ############
######################## 下面是磁盘限额Quota设置 ############ #启用磁盘限额
#启用磁盘限额 QuotaDirectoryTally on
QuotaDirectoryTally on

 #磁盘限额单位 b"|"Kb"|"Mb"|"Gb"
#磁盘限额单位 b"|"Kb"|"Mb"|"Gb" QuotaDisplayUnits "Mb"
QuotaDisplayUnits "Mb"
 QuotaEngine on
QuotaEngine on
 #磁盘限额日志记录
#磁盘限额日志记录 QuotaLog "/var/log/proftpd.quotalog"
QuotaLog "/var/log/proftpd.quotalog"
 #打开磁盘限额信息 "quote SITE QUOTA"命令
#打开磁盘限额信息 "quote SITE QUOTA"命令 QuotaShowQuotas on
QuotaShowQuotas on ####################### 完成磁盘配额设置 ####################
####################### 完成磁盘配额设置 ####################







 SQLConnectInfo ftp@localhost:3306 root 123456
SQLConnectInfo ftp@localhost:3306 root 123456 SQLAuthTypes Backend Plaintext
SQLAuthTypes Backend Plaintext


 #指定用来做用户认证的表的有关信息。(将在后面创建)
#指定用来做用户认证的表的有关信息。(将在后面创建) SQLUserInfo FTPUSERS userid passwd uid gid homedir shell
SQLUserInfo FTPUSERS userid passwd uid gid homedir shell SQLGroupInfo FTPGRPS groupname gid members
SQLGroupInfo FTPGRPS groupname gid members
 #数据库认证
#数据库认证 SQLAuthenticate users groups usersetfast groupsetfast
SQLAuthenticate users groups usersetfast groupsetfast
 #proftpd进行的mysql调用语句,别修改任何地方
#proftpd进行的mysql调用语句,别修改任何地方 SQLNamedQuery get-quota-limit SELECT "name, quota_type, per_session, limit_type, bytes_in_avail, bytes_out_avail, bytes_xfer_avail,files_in_avail, files_out_avail, files_xfer_avail FROM quotalimits WHERE name = '%{0}' AND quota_type = '%{1}'"
SQLNamedQuery get-quota-limit SELECT "name, quota_type, per_session, limit_type, bytes_in_avail, bytes_out_avail, bytes_xfer_avail,files_in_avail, files_out_avail, files_xfer_avail FROM quotalimits WHERE name = '%{0}' AND quota_type = '%{1}'"
 SQLNamedQuery get-quota-tally SELECT "name, quota_type, bytes_in_used, bytes_out_used, bytes_xfer_used, files_in_used, files_out_used, files_xfer_used FROM quotatallies WHERE name = '%{0}' AND quota_type = '%{1}'"
SQLNamedQuery get-quota-tally SELECT "name, quota_type, bytes_in_used, bytes_out_used, bytes_xfer_used, files_in_used, files_out_used, files_xfer_used FROM quotatallies WHERE name = '%{0}' AND quota_type = '%{1}'"
 SQLNamedQuery update-quota-tally UPDATE "bytes_in_used = bytes_in_used + %{0}, bytes_out_used = bytes_out_used + %{1}, bytes_xfer_used = bytes_xfer_used + %{2}, files_in_used = files_in_used + %{3}, files_out_used = files_out_used + %{4}, files_xfer_used = files_xfer_used + %{5} WHERE name = '%{6}' AND quota_type = '%{7}'" quotatallies
SQLNamedQuery update-quota-tally UPDATE "bytes_in_used = bytes_in_used + %{0}, bytes_out_used = bytes_out_used + %{1}, bytes_xfer_used = bytes_xfer_used + %{2}, files_in_used = files_in_used + %{3}, files_out_used = files_out_used + %{4}, files_xfer_used = files_xfer_used + %{5} WHERE name = '%{6}' AND quota_type = '%{7}'" quotatallies
 SQLNamedQuery insert-quota-tally INSERT "%{0}, %{1}, %{2}, %{3}, %{4}, %{5}, %{6}, %{7}" quotatallies
SQLNamedQuery insert-quota-tally INSERT "%{0}, %{1}, %{2}, %{3}, %{4}, %{5}, %{6}, %{7}" quotatallies
 QuotaLimitTable sql:/get-quota-limit
QuotaLimitTable sql:/get-quota-limit QuotaTallyTable sql:/get-quota-tally/update-quota-tally/insert-quota-tally
QuotaTallyTable sql:/get-quota-tally/update-quota-tally/insert-quota-tally





 CreateHome on
CreateHome on






 # To cause every FTP user to be "jailed" (chrooted) into their home
# To cause every FTP user to be "jailed" (chrooted) into their home # directory, uncomment this line.
# directory, uncomment this line. DefaultRoot ~
DefaultRoot ~
 # Normally, we want files to be overwriteable.
# Normally, we want files to be overwriteable. AllowOverwrite          on
AllowOverwrite          on
 # Bar use of SITE CHMOD by default
# Bar use of SITE CHMOD by default <Limit SITE_CHMOD>
<Limit SITE_CHMOD> AllowAll
  AllowAll </Limit>
</Limit>
 # A basic anonymous configuration, no upload directories.  If you do not
# A basic anonymous configuration, no upload directories.  If you do not # want anonymous users, simply delete this entire <Anonymous> section.
# want anonymous users, simply delete this entire <Anonymous> section. <Anonymous ~ftp>
<Anonymous ~ftp> # User                          ftp
# User                          ftp # Group                         ftp
# Group                         ftp
 # We want clients to be able to login with "anonymous" as well as "ftp"
  # We want clients to be able to login with "anonymous" as well as "ftp" UserAlias                     anonymous ftp
  UserAlias                     anonymous ftp
 # Limit the maximum number of anonymous logins
  # Limit the maximum number of anonymous logins MaxClients                    10
  MaxClients                    10
 # We want 'welcome.msg' displayed at login, and '.message' displayed
  # We want 'welcome.msg' displayed at login, and '.message' displayed # in each newly chdired directory.
  # in each newly chdired directory. DisplayLogin                  welcome.msg
  DisplayLogin                  welcome.msg DisplayChdir                  .message
  DisplayChdir                  .message
 # Limit WRITE everywhere in the anonymous chroot
  # Limit WRITE everywhere in the anonymous chroot <Limit WRITE>
  <Limit WRITE> DenyAll
    DenyAll </Limit>
  </Limit> </Anonymous>
</Anonymous>



 proftpd 建表
proftpd 建表 CREATE TABLE FTPGRPS(
CREATE TABLE FTPGRPS( groupname text NOT NULL,
groupname text NOT NULL, gid smallint(6) NOT NULL default 0,
gid smallint(6) NOT NULL default 0, members text NOT NULL
members text NOT NULL )
)

 INSERT INTO FTPGRPS VALUES ('FTPGRP', 2001, 'FTPUSR');
INSERT INTO FTPGRPS VALUES ('FTPGRP', 2001, 'FTPUSR'); INSERT INTO FTPGRPS VALUES ('ftpusers', 2002, 'ftp');
INSERT INTO FTPGRPS VALUES ('ftpusers', 2002, 'ftp');
 CREATE TABLE FTPUSERS (
CREATE TABLE FTPUSERS ( userid text NOT NULL,
userid text NOT NULL, passwd text NOT NULL,
passwd text NOT NULL, uid int(11) NOT NULL default '0',
uid int(11) NOT NULL default '0', gid int(11) NOT NULL default '0',
gid int(11) NOT NULL default '0', homedir text,
homedir text, shell text
shell text )
)

 INSERT INTO FTPUSERS VALUES ('lcx1', '123456', 2001, 2001, '/home/www/lcx1', "");
INSERT INTO FTPUSERS VALUES ('lcx1', '123456', 2001, 2001, '/home/www/lcx1', "");

 CREATE TABLE quotalimits (
CREATE TABLE quotalimits ( name varchar(30) default NULL,
name varchar(30) default NULL, quota_type enum('user','group','class','all') NOT NULL default 'user',
quota_type enum('user','group','class','all') NOT NULL default 'user', per_session enum('false','true') NOT NULL default 'false',
per_session enum('false','true') NOT NULL default 'false', limit_type enum('soft','hard') NOT NULL default 'soft',
limit_type enum('soft','hard') NOT NULL default 'soft', bytes_in_avail float NOT NULL default 0,
bytes_in_avail float NOT NULL default 0, bytes_out_avail float NOT NULL default 0,
bytes_out_avail float NOT NULL default 0, bytes_xfer_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_in_avail int(10) unsigned NOT NULL default 0, files_out_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
files_xfer_avail int(10) unsigned NOT NULL default 0 )
)


 CREATE TABLE quotatallies (
CREATE TABLE quotatallies ( name VARCHAR(30) NOT NULL,
 name VARCHAR(30) NOT NULL, quota_type ENUM("user", "group", "class", "all") NOT NULL,
 quota_type ENUM("user", "group", "class", "all") NOT NULL, bytes_in_used FLOAT NOT NULL,
 bytes_in_used FLOAT NOT NULL, bytes_out_used FLOAT NOT NULL,
 bytes_out_used FLOAT NOT NULL, bytes_xfer_used FLOAT NOT NULL,
 bytes_xfer_used FLOAT NOT NULL, files_in_used INT UNSIGNED NOT NULL,
 files_in_used INT UNSIGNED NOT NULL, files_out_used INT UNSIGNED NOT NULL,
 files_out_used INT UNSIGNED NOT NULL, files_xfer_used INT UNSIGNED NOT NULL
 files_xfer_used INT UNSIGNED NOT NULL );
 );
2008年8月27日
无法计算实际FTP文件大小<-----抱歉,没有深入了解他的配置,proftpd新版已经可以实时计算空间大小了。
QuotaOptions ScanOnLogin #登录时扫描用户home目录更新文件大小和数量
 
                    
                     
                    
                 
                    
                
 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号