亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 服務器 > 管理維護 > 正文

proftpd學習筆記(四)

2024-09-10 14:18:51
字體:
來源:轉載
供稿:網友

今天我們講proftp+mysql+quota的應用,我想大家最期待的就是這個了吧

1.首先我們建立相應的用戶和用戶組

groupadd -g 5500 ftpgroup
adduser -u 5500 -s /bin/false -d /bin/null -c "proftpd user" -g ftpgroup ftpuser

2.操作數據庫

mysql 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',
`accessed` datetime NOT NULL default '0000-00-00 00:00:00',
`modified` datetime NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (`id`)
) TYPE=MyISAM COMMENT='ProFTP user table' ;

注意這里大家根據實際情況填寫自己數據庫的用戶名和密碼,如果大家對數據庫操作不熟悉的話,不妨可以用phpmyadmin來操作。

3.配置proftp文件

ServerName "Frank's FTP Server" ServerType standalone DefaultServer on

Port 21

Umask 022

MaxInstances 30
MaxLoginAttempts 3

User nobody
Group nobody

MaxHostsPerUser 1 "Sorry, you may not connect more than one time."
MaxClientsPerUser 2 "Only one such user at a time."
MaxClientsPerHost 3 "Sorry, you may not connect more than one time."

RootLogin off
RequireValidShell off
TimeoutStalled 10
MaxClients 10
AllowForeignAddress on
AllowStoreRestart on
ServerIdent off
DefaultRoot ~ ftpgroup

SQLAuthTypes Backend Plaintext
#Backend表示用戶認證方式為MySQL數據庫的認證方式
#Plaintext表示明文認證方式,排在最前面的為最先使用的方式
SQLAuthenticate users* groups*

# databasename@host database_user user_password
SQLConnectInfo ftpdb@localhost proftpd password
SQLUserInfo ftpuser userid passwd uid gid homedir shell
SQLGroupInfo ftpgroup groupname gid members
SQLHomedirOnDemand on
#如果用戶主目錄不存在,則系統會根據此用戶在用戶數據表中的homedir字段的值新建一個目錄
# Update count every time user logs in
SQLLog PASS updatecount
SQLNamedQuery updatecount UPDATE "count=count+1,accessed=now() WHERE userid='%u'" ftpuser
# Update modified everytime user uploads or deletes a file
SQLLog STOR,DELE modified
SQLNamedQuery modified UPDATE "modified=now() WHERE userid='%u'" ftpuser

QuotaEngine on
QuotaDirectoryTally on
QuotaDisplayUnits Mb
QuotaShowQuotas on
QuotaLog "/var/log/quota"
SQLNamedQuery get-quota-limit SELECT "name, quota_type, per_session, limit_type, bytes_in_avail, bytes_out_avai
l, bytes_xfer_avail, files_in_avail, files_out_avail, files_xfer_avail FROM ftpquotalimits 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_i
n_used, files_out_used, files_xfer_used FROM ftpquotatallies 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}'" ftpquota
tallies

SQLNamedQuery insert-quota-tally INSERT "%{0}, %{1}, %{2}, %{3}, %{4}, %{5}, %{6}, %{7}" ftpquotatallies

QuotaLimitTable sql:/get-quota-limit
QuotaTallyTable sql:/get-quota-tally/update-quota-tally/insert-quota-tally


ok,就這么簡單,重啟一下proftp服務就已經能使用proftp+mysql+quota的功能

我們可以在數據庫ftpuser添加一個虛擬用戶,

INSERT INTO `ftpuser` VALUES (1, 'test', 'ftppasswd', 5500, 5500, '/home/test', '/sbin/nologin');

大家可以在phpmyadmin里直接操作添加一個用戶,相信不用我教大家怎么添加吧:)

如果你想設置quota,只要在ftpquotalimits表里設置一下就行了,這個表里的各個參數分別代表:

quotalimits表

name: - 用戶帳號
quota type: - user, group, class, all (we use user)
per_session: - true or false (we use true)
limit_type: - 硬限制 or 軟限制 (我們一般用硬限制)
bytes_in_avail: - 允許上傳的字節數
bytes_out_avail: - 允許下載的字節數
bytes_xfer_avail: - 允許傳輸的字節數(包括上傳/下載)
files_in_avail: - 允許上傳的文件數
files_out_avail: - 允許下載的文件數
files_xfer_avail: - 允許傳輸的文件數(包括上傳/下載)

老實說用mysql和quota模塊來驗證用戶和設置磁盤限額,但我總覺得還是不夠完善,因為在這個方法中,數據庫表里還沒有相應的權限的字段,所以說相應用戶的權限還是得用實際得用戶即mysql對應得uid和gid來控制權限,那天要是mysql數據庫也能完全控制權限就好了。

大家如果覺得格式拷貝的時候可能會出錯的話,不妨直接下載我的配置文件和數據庫表

下載proftpd.conf
下載ftpdb.sql

只是我的數據庫表里對應的uid和gid都是5500,大家可根據自己的情況修改:)注意消化哦。

這個春節一直在學習proftp,終于可以松口氣了,希望我的學習筆記可以對一些想學習proftp的朋友有所幫助,請多交流

相關文章:
proftpd學習筆記(一)
proftpd學習筆記(二)
proftpd學習筆記(三)

參考文檔:
Mandrake 9.2 + Proftpd + MySQL authentication + Quotas Howto
proftpd + mysql + quota配置完全指南
Proftpd Configuration Docs

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产脚交av在线一区二区| 永久免费毛片在线播放不卡| 欧美福利视频在线观看| 欧美激情视频网址| 中文字幕免费国产精品| 精品久久久免费| 亚洲免费视频观看| 韩国三级日本三级少妇99| 欧日韩不卡在线视频| 欧美激情在线视频二区| 欧美成aaa人片在线观看蜜臀| 国产精品偷伦免费视频观看的| 亚洲人成在线免费观看| 亚洲福利视频免费观看| 久久精品国产一区| 欧美视频在线免费| 成人性生交大片免费看视频直播| 亚洲最大福利视频网站| 韩曰欧美视频免费观看| 992tv成人免费视频| 亚洲视频精品在线| 国产精品成人一区| 国产一区二区三区高清在线观看| 国产日产亚洲精品| 黑人巨大精品欧美一区二区一视频| 久久影院在线观看| 国产91色在线|免| 欧美日本高清视频| 日本高清不卡在线| 亚洲精品按摩视频| 国产激情久久久久| 亚洲天堂成人在线| 不卡av日日日| 国外日韩电影在线观看| 国产精品视频精品| 欧美日韩国产成人在线| 日韩电影视频免费| 欧美第一黄色网| 久久久免费高清电视剧观看| 精品福利视频导航| 日韩精品在线免费| 欧美性在线观看| 神马国产精品影院av| 亚洲美女在线观看| 中文字幕欧美日韩va免费视频| 96pao国产成视频永久免费| 色一情一乱一区二区| 亚洲国产精品久久久久秋霞蜜臀| 欧美在线视频网| 国产精品亚洲美女av网站| 欧美激情精品久久久久久久变态| 精品亚洲夜色av98在线观看| 久久99亚洲精品| 欧美成人黄色小视频| 欧美在线视频在线播放完整版免费观看| 国产女人精品视频| 久久久久久午夜| 热re99久久精品国产66热| 亚洲成年人在线播放| 国产成人a亚洲精品| 国产成人精品日本亚洲| 成人黄色大片在线免费观看| 日韩av第一页| 亚洲第一精品福利| 国产91精品久| 欧美大片在线看免费观看| 国产精品日本精品| 国产欧美精品一区二区三区介绍| 国产精品综合网站| 日韩电影视频免费| 亚洲bt欧美bt日本bt| 中文欧美在线视频| 日韩精品中文字幕在线观看| 亚洲欧美自拍一区| 亚洲精品久久久久久久久久久久| 久久高清视频免费| 国产精品美女www爽爽爽视频| 97涩涩爰在线观看亚洲| 国产午夜精品全部视频在线播放| 欧美日韩国产成人在线观看| 亚洲无线码在线一区观看| 国产精品久久不能| 黄色一区二区在线| 久热精品视频在线观看一区| 亚洲乱码国产乱码精品精| 欧美国产日韩一区二区三区| 欧美极品少妇xxxxⅹ免费视频| 亚洲福利视频专区| 日韩高清中文字幕| 91色视频在线导航| 日韩在线视频观看正片免费网站| 日韩欧美亚洲综合| 久久精品人人做人人爽| 一二美女精品欧洲| 国产主播欧美精品| 欧美人成在线视频| 日韩精品亚洲元码| 国产精品成人久久久久| 久久久国产精彩视频美女艺术照福利| 成人免费视频网| 欧美国产在线视频| 奇米影视亚洲狠狠色| 久久精品国产亚洲7777| 色综合久久88色综合天天看泰| 亚洲精品99久久久久| 欧美插天视频在线播放| 91精品国产高清久久久久久91| 亚洲深夜福利网站| 美女少妇精品视频| 亚洲福利在线播放| 成人精品在线观看| 亚洲乱码国产乱码精品精| 亚洲精品美女在线观看播放| 97涩涩爰在线观看亚洲| 欧美成人小视频| 国产美女精品视频免费观看| 欧美中文字幕在线| 久久久精品一区二区三区| 欧美性做爰毛片| 成人精品久久久| 中文字幕国产精品| 日韩高清av在线| 精品国产一区久久久| 国产精品pans私拍| 久久亚洲精品国产亚洲老地址| 日韩美女毛茸茸| 91欧美精品成人综合在线观看| 日韩精品视频在线| 亚洲三级 欧美三级| 色樱桃影院亚洲精品影院| 日韩成人av在线| 91sao在线观看国产| 免费99精品国产自在在线| 在线观看日韩视频| 欧美精品激情视频| 91精品久久久久久久久久久久久久| 日韩av片电影专区| 亚洲欧美日韩在线高清直播| 国产69久久精品成人| 日韩精品视频免费在线观看| 国产亚洲精品久久久久动| 久久五月天色综合| 亚洲天堂第二页| 亚洲日韩中文字幕在线播放| 欧美在线观看视频| 狠狠色狠狠色综合日日小说| 日韩免费观看av| 中文字幕日韩在线视频| 国产精品黄色影片导航在线观看| 精品无人区太爽高潮在线播放| 亚洲男人的天堂在线播放| 日本道色综合久久影院| 亚洲人成网站999久久久综合| 中国人与牲禽动交精品| 亚洲一区二区三区四区在线播放| 国产精品美女呻吟| 98视频在线噜噜噜国产| 欧美精品video| 日韩小视频在线| 视频在线观看一区二区| 国产亚洲一区精品| 国模私拍一区二区三区| 青青精品视频播放| 欧美激情中文字幕乱码免费|