基本需求:实现ftp账号到期自动关闭、延期、限额、限速操作, 


系统搭建

系统:centos6.4

软件:pureftpd+mysql

软件版本:pure-ftpd-1.0.36

安装:

#yum -y install httpd mysql-devel mysql-server gcc

#tar xvf pure-ftpd-1.0.36.tar.gz

#cd pure-ftpd-1.0.36

#./configure--prefix=/usr/local/pure-ftpd/ --with-everything --with-altlog --with-puredb--with-ftpwho --with-mysql --with-throttling --with-ratios --with-quotas--with-virtualhosts --with-virtualchroot --with-sysquotas --with-cookie--with-rfc2640 --with-bonjour --with-welcomemsg --with-language=simplified-chinese--with-uploadscript

#make&make install

#mkdir /usr/local/pure-ftpd/etc/

#cpconfiguration-file/pure-ftpd.conf /usr/local/pure-ftpd/etc/

#cpconfiguration-file/pure-config.pl /usr/local/pure-ftpd/sbin/

#cppureftpd-mysql.conf /usr/local/pure-ftpd/etc/

#chmod755 /usr/local/pure-ftpd/sbin/pure-config.pl

部分截图

 ftp之 pure-ftp_pure-ftp

#ln-s /usr/local/pure-ftpd/bin/* /usr/local/bin/

#ln-s /usr/local/pure-ftpd/sbin/* /usr/local/sbin/

#ln-s /usr/local/pure-ftpd/share/man/man8/* /usr/local/share/man/man8/

#groupadd-g 10000 hzftp

#useradd-u 10000 -g 10000 -d /var/ftp -s /sbin/nologin hzftp

#passwd hzftp          (123456)          

#cp/etc/skel/.b* /mnt/hzftpdata/    注:/mnt/hzftpdata 为ftp账号的存储目录 

#vi/usr/local/pure-ftpd/etc/pure-ftpd.conf

VerboseLog                 yes

NoAnonymous                 yes

MySQLConfigFile              /usr/local/pure-ftpd/etc/pureftpd-mysql.conf

PassivePortRange          30000 50000

MinUID                      10000

AltLog                     clf:/var/log/pureftpd.log

AltLog                    stats:/var/log/pureftpd.log

AltLog                     w3c:/var/log/pureftpd.log

reateHomeDir               yes

Quota                       1000:10


创建数据库

#mysql

createdatabase pureftpd;

grantselect on pureftpd.* to hzftp@localhost identified by '456789';

flushprivileges;

createtable if not exists `users`( `user` varchar(16) not null default '', `password`varchar(32) not null default '',`startdate` date not null, `enddate` date notnull, `uid` int(11) not null, `gid` int (11) not null, `dir` varchar(128) notnull default '', `quotafiles` int(10) not null default '10000', `quotasize`int(10) not null default '1000', `ulbandwidth` int(10) not null, `dlbandwidth`int(10) not null, `ipaddress` varchar(15) not null default '*', `comment`tinytext, `status` enum('0','1') not null default '1', `ulratio` smallint(5)not null default '1', `dlratio` smallint(5) not null default '1',`email`varchar(50) not null default '', primary key (`user`), unique key `user`(`user`) )engine=innodb default charset=utf8;

 ftp之 pure-ftp_安装_02

实际使用过程中发现自带的账号关闭功能不是很理想,所以考虑使用两张表users和closedftp.

分别存储活动账号和已关闭账号信息

create table closedftp select * from users;

 ftp之 pure-ftp_安装_03

 ftp之 pure-ftp_安装_04

 ftp之 pure-ftp_安装_05

修改数据库配置

vi pureftpd-mysql.conf

MYSQLSocket     /var/lib/mysql/mysql.sock

MYSQLUser      hzftp

MYSQLPassword   456789

MYSQLCrypt      md5

启动 mysql及ftp服务

#service mysqld start

#/usr/local/pure-ftpd/sbin/pure-config.pl /usr/local/pure-ftpd/etc/pure-ftpd.conf

至此ftp搭建完毕,通过操作mysql实现用户管理比较麻烦

在这里本人通过脚本实现

内容如下:


more ftp-manage.sh 

#/bin/bash

HOSTNME="127.0.0.1"

PORT="3306"

USERNAME="hzftp"

PASSWORD="456789"

DBNAME="pureftpd"

TABLENAME="users"

TABLENAME1="closedftp"

#closeday=(date +%Y-%m-%d)

#shutday=(date +%Y-%m-%D)

echo "select operation;"

echo "1):添加账号"

echo "2):修改密码"

echo "3):禁用账号"

echo "4):自动禁用"

echo "5):已关闭账号延期"

echo "6):使用中账号延期"

echo "7):查看账号信息"

echo "please select operation"

read operation

case "$operation" in


1)

read -p "input ftp name:" name

read -p "input ftp password:" pass

read -p "input closeday:(格式为0000-00-00)" closeday

sql="select max(uid) from users limit 1"

echo "用户ID一般为依次递增,目前ID已使用至"

sql_max="select max(uid) from users limit 1"

echo &(mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql_max}")

read -p "input user ID:" ud

read -p "input quota  size:" qsize

userhome=/mnt/hzftpdata/$name

echo 信息确认

echo 用户名:"$name",密码:"$pass",关闭日期:"$closeday",用户ID:"$ud",限额:"$qsize",路径:"$userhome"

echo "ctrl+ C" 取消操作

sleep 10

sql="insert into users values ('$name','$pass','$(date +%Y-%m-%d)','$closeday','$ud','10000','$userhome','10000','$q

size','300','300','','','1','1','1','')"

sql1="select user,password,startdate,enddate,uid,gid,dir from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

echo "信息已确认:"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql1}" 

;;

2)

read -p "input name:" name

read -p "input pass:" pass

sql="update users set password='$pass' where user='$name'"

sql2="select user,password,dir,enddate from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql2}" 

;;

3)

read -p "input name:" name

sql="update users set status='0' where user='$name'"

sql2="insert into closedftp select * from users where status='0' and user='$name'"

sql3="delete from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql2}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql3}" 

;;

4)

sql="update users set status='0' where enddate<='$(date +%Y-%m-%d)'"

sql2="insert into closedftp select * from users where enddate<='$(date +%Y-%m-%d)'"

sql3="delete from users where enddate<='$(date +%Y-%m-%d)'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql2}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql3}" 

;;

5)

read -p "请输入要延期的账号:" name

read -p "延期时间(格式0000-00-00):" closeday

sql="update closedftp set enddate='$closeday',status='1' where user='$name'"

sql2="insert into users select * from closedftp where user='$name'"

sql3="delete from closedftp where user='$name'"

sql4="select user,password,dir,enddate from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql2}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql3}" 

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql4}" 

;;

6)

read -p "请输入要延期的账号:" name

read -p "延期时间(格式0000-00-00):" closeday

sql="update users set enddate='$closeday' where user='$name'"

sql2="select user,dir,enddate from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

echo "信息已更改"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql2}" 

;;

7)

read -p "input name:" name

sql="select user,password,dir,startdate,enddate from users where user='$name'"

mysql -h ${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${sql}" 

;;

*) echo "Error,please select 1,2,3,or 4:"

;;

esac