Pureftpd 和 mysql 架设FTP服务器

系统 Linux
Pureftpd是一款在多种类Unix上使用并符合GPL协议的原代码开放的软件,顾名思义,它就是一款纯粹的Ftp程序。本文给大家介绍下如何利用 Pureftpd 和 mysql 架设FTP服务器。

Pureftpd是一款快速,高质量,功能齐全的ftp服务器,最重要的是可以支持设置客户端默认编码,今天我给大家详细介绍下:Pureftpd 和 mysql 架设FTP服务器的具体过程。

  下载mysql5.1.31 rpm文件和pure-ftpd源码包

  安装mysql5.1.31共享包

  rpm -ivh MySQL-shared-community-5.1.31-0.rhel5.i386.rpm

  编译安装pure-ftpd

 

  1.   #./configure –prefix=/usr/local/pureftpd –with-mysql –with-paranoidmsg –with-welcomemsg –with-uploadscript –with-cookie –with-virtualchroot –with-virtualhosts –with-virtualroot –with-diraliases –with-quotas –with-sysquotas –with-ratios –with-ftpwho –with-throttling  
  2.  
  3.   #make  
  4.  
  5.   #make check  
  6.  
  7.   #make install  

 

  配置pure-ftpd

 

  1.   #cd configuration-file  
  2.  
  3.   #chmod u+x pure-config.pl  
  4.  
  5.   #cp pure-config.pl /usr/local/sbin/  
  6.  
  7.   #cp pure-ftpd.conf /usr/local/etc/  
  8.  
  9.   vi /usr/local/etc/pure-ftpd.conf  

 

  确认以下三项

  ChrootEveryone yes

  MySQLConfigFile /etc/pureftpd-mysql.conf

  CreateHomeDir yes

  为puer-ftpd创建mysql数据库和用户

  CREATE DATABASE pureftpd;

  GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON pureftpd.* TO ‘pureftpd’@'localhost’ IDENTIFIED BY ‘password’;

  FLUSH PRIVILEGES;

  USE pureftpd;

  CREATE TABLE ftpd (

  User varchar(16) NOT NULL default ”,

  status enum(’0′,’1′) NOT NULL default ’0′,

  Password varchar(64) NOT NULL default ”,

  Uid varchar(11) NOT NULL default ‘-1′,

  Gid varchar(11) NOT NULL default ‘-1′,

  Dir varchar(128) NOT NULL default ”,

  ULBandwidth smallint(5) NOT NULL default ’0′,

  DLBandwidth smallint(5) NOT NULL default ’0′,

  comment tinytext NOT NULL,

  ipaccess varchar(15) NOT NULL default ‘*’,

  QuotaSize smallint(5) NOT NULL default ’0′,

  QuotaFiles int(11) NOT NULL default 0,

  PRIMARY KEY (User),

  UNIQUE KEY User (User)

  ) TYPE=MyISAM;

  配置pureftpd-mysql.conf

  vi /etc/pureftpd-mysql.conf

  录入

  MYSQLSocket /tmp/mysql.sock

  #MYSQLServer localhost

  #MYSQLPort 3306

  MYSQLUser pureftpd

  MYSQLPassword password

  MYSQLDatabase pureftpd

  #MYSQLCrypt md5, cleartext, crypt() or password() – md5 is VERY RECOMMENDABLE uppon cleartext

  MYSQLCrypt md5

  MYSQLGetPW SELECT Password FROM ftpd WHERE User=”L” AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MYSQLGetUID SELECT Uid FROM ftpd WHERE User=”L” AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MYSQLGetGID SELECT Gid FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MYSQLGetDir SELECT Dir FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MySQLGetBandwidthUL SELECT ULBandwidth FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MySQLGetBandwidthDL SELECT DLBandwidth FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MySQLGetQTASZ SELECT QuotaSize FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

  MySQLGetQTAFS SELECT QuotaFiles FROM ftpd WHERE User=”L”AND status=”1″ AND (ipaccess = “*” OR ipaccess LIKE “R”)

#p#

  各参数注释

  User:用户名

  status:状态 1为激活状态 0为非激活状态

  Password :密码

  Uid:用户系统ID号

  GID:用户组ID号

  ULBandwidth :上传***带宽 单位 KB/S

  DLBandwidth:下载***带宽 单位 KB/S

  comment :注释

  ipaccess :允许访问IP地址

  QuotaSize :磁盘配额总大小 单位MB

  QuotaFiles :允许存放的文件数目个数 0为不限制

  关掉进程

  killall pure-ftpd

  启动服务

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

  为ftp添加用户

  USE pureftpd;

  INSERT INTO `ftpd` (`User`, `status`, `Password`, `Uid`, `Gid`, `Dir`, `ULBandwidth`, `DLBandwidth`, `comment`, `ipaccess`, `QuotaSize`, `QuotaFiles`) VALUES (‘test’, ’1′, MD5(‘test’), ’60031′, ’60031′, ‘/home/test’, ’128′, ’56′, ”, ‘*’, ’100′, ’0′);

  即可用数据库里的用户和密码登陆ftp

  将pureftpd加载为系统服务

  vi /etc/init.d/pureftpd

  录入

 

  1.   #!/bin/bash  
  2.  
  3.   # chkconfig: 35 95 1  
  4.  
  5.   # description: script to start/stop pureftpd  

 

  case $1 in

  start)

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

  ;;

  stop)

  killall pure-ftpd

  ;;

  *)

  echo “Usage: $0 (start|stop)”

  ;;

  esac

  更改权限

  # chmod 775 pureftpd

  加入自动启动

  # chkconfig –add pureftpd

  查看自动启动设置

  # chkconfig –list pureftpd

  pureftpd 0:off 1:off 2:off 3:on 4:off 5:on 6:off

  以后可以用以下命令启动和停止脚本

  # service pureftpd start 启动

  # service pureftpd stop 停止

  启动和停止mysql服务

  #service mysql start

  #service mysql stop

  若无法上传文件,设置ftp文件夹权限

  chmod -R 777 /data0/htdocs

通过文章的介绍和分析,我们可以清楚的知道利用Pureftpd 和 mysql 架设FTP服务器的详细过程。希望本文对大家有所帮助!

【编辑推荐】

  1. Debian5 LNMP编译安装pureftpd手册
  2. pureftpd ubuntu配置指南
  3. ubuntu 下 Pureftpd 常用配置
  4. Pureftpd攻略之启动篇
  5. Lnmp之Pureftpd管理面板安装教程(图文)
  6. Pureftpd.conf的设定
  7. vsFTPd 服务器初学者精通手册
责任编辑:赵鹏 来源: 网络转载
相关推荐

2011-03-03 10:57:47

pureftpdslackware

2010-07-01 17:13:53

2011-07-28 13:36:53

2010-04-13 17:12:54

2011-02-23 09:01:37

2011-03-02 10:32:18

2009-02-27 13:33:00

2019-02-26 16:20:52

FTP服务器

2011-08-08 13:52:32

服务器

2010-01-04 13:26:51

Ubuntu安装

2011-03-03 09:40:58

2011-08-08 14:31:49

服务器

2011-03-07 17:04:02

ProftpdFTP

2009-02-27 14:31:00

2009-12-10 17:20:00

PHP服务器架设

2010-07-01 14:22:02

配置FTP服务器

2010-08-30 20:13:25

DHCP服务器

2009-02-27 13:22:00

2010-07-01 12:22:40

ftp命令FTP协议

2009-08-25 12:37:38

个人服务器架设
点赞
收藏

51CTO技术栈公众号