源码安装配置pure-ftp

看看端口有没有起来吧  netstat -lnp  有没有21端口开启。
我有一篇安装配置pure-ftp的文章,你可以做个参考。
下载最新的pure-ftp源码包pure-ftpd-1.0.21.tar.bz2   
# wget pure-ftpd-1.0.21.tar.bz2
#tar jxvf pure-ftpd-1.0.21.tar.bz2
#cd pure-ftpd-1.0.21
./configure --prefix=/usr/local/pureftpd --without-inetd --with-altlog --with-puredb --with-throttling --with-largefile --with-peruserlimits --with-tls --with-language=simplified-chinese
#make && make install
启动
用配置文件
#mkdir /usr/local/pureftpd/etc
#cd configuration-file
#cp pure-ftpd.conf /usr/local/pureftpd/etc/pure-ftpd.conf
#cp pure-config.pl  /usr/local/pureftpd/sbin/pure-config.pl
#chmod 755 /usr/local/pureftpd/sbin/pure-config.pl

启动pure-ftp之前需要先修改配置文件,配置文件为/usr/local/pureftpd/etc/pure-ftpd.conf
启动命令: /usr/local/pureftpd/sbin/pure-config.pl /usr/local/pureftpd/etc/pure-ftpd.conf
下面是我的配置文件,如果你嫌麻烦,直接拷贝过去即可。

____________________________________

ChrootEveryone              yes

BrokenClientsCompatibility  no

MaxClientsNumber            50

Daemonize                   yes

MaxClientsPerIP             8

VerboseLog                  no

DisplayDotFiles             yes

AnonymousOnly               no

NoAnonymous                 no

SyslogFacility              ftp

DontResolve                 yes

MaxIdleTime                 15

PureDB                        /usr/local/pureftpd/etc/pureftpd.pdb

LimitRecursion              2090 8

AnonymousCanCreateDirs      no

MaxLoad                     4

AntiWarez                   yes

Umask                       133:022

MinUID                      100

AllowUserFXP                no

AllowAnonymousFXP           no

ProhibitDotFilesWrite       no

ProhibitDotFilesRead        no

AutoRename                  no

AnonymousCantUpload         no

PIDFile                     /usr/local/pureftpd/var/run/pure-ftpd.pid

MaxDiskUsage               99

CustomerProof              yes

####################################到此结束,保存即可

启动命令: /usr/local/pureftpd/sbin/pure-config.pl /usr/local/pureftpd/etc/pure-ftpd.conf

#######接下来该建立用户了###############

# /usr/local/pureftpd/bin/pure-pw useradd ftp_test -u www -d /data/wwwroot其中,-u 将虚拟用户 ftp_test 与系统用户 www 关联在一起。-d 参数使 ftp_test 只能访问其主目录。执行完上述命令后,会提示输入密码。
最后一步也是至关重要的,就是创建用户的数据库。
# /usr/local/pureftpd/bin/pure-pw mkdb

------------------------------------------------------------------------------------------------------------------------------------

[

pure-ftp默认采用Linux的root用户。采用virtual users(虚拟帐户) 则能够更好的控制访问权项。

建立一个ftp用户的文件夹,也就是ftp共享文件夹。
#mkdir /usr/local/ftpdir

建立一个ftp用户与组:
#groupadd ftpgroup
#useradd -g ftpgroup -d /usr/local/nginx/html -s /bin/bash ftpftp
进入安装执行目录
#cd /usr/local/pureftp/bin

建立第一个虚拟用户:
#pure-pw useradd widebright -u ftpftp -d /usr/local/nginx/html/ -f /usr/local/pureftp/pure-ftpd.passwd
运行之后会提示你输入一个 widebright用户的密码。
说明: widebright 就是要创建FTP登陆账户 ,ftpftp 是关联的linux用户,
-d指定起始目录,并锁定于该目录。如果不锁定,则用-D 如果需要不同的权限,可以使用chown chmod配置linux用户与组的指定目录的权限,
-f 指定生成的密码文件的保存位置。
如果想修改用户,可以自己查看pure-pw命令的用法。
如果提示-bash: pure-pw: command not found, 即环境变量里没有这个路径,不添加路径的话要指定pure-pw的绝对路径
这里是: /usr/local/pureftp/bin/pure-pw useradd widebright -u ftpftp -d /usr/local/nignx/html -f /usr/local/pureftp/pure-ftpd.passwd
之后会提示输入密码和再次输入密码: Password: Enter it again:

4. 生成密码数据库
#pure-pw mkdb /usr/local/pureftp/pure-ftpd.pdb -f /usr/local/pureftp/pure-ftpd.passwd
/usr/local/pureftp/pure-ftpd.pdb 是要生成的密码数据库保存的位置。-f 指定根据那个密码文件生成,
这里采用的是先前生成的包含widebright用户的密码配置文件。/usr/local/pureftp/pure-ftpd.passwd
这是为:
#/usr/local/pureftp/bin/pure-pw mkdb /usr/local/pureftp/pure-ftpd.pdb -f /usr/local/pureftp/pure-ftpd.passwd

5. 启动pure-ftpd 服务器。
# /usr/local/pureftp/sbin/pure-ftpd -l puredb:/usr/local/pureftp/pure-ftpd.pdb & ====这里还是用的绝对路径
-l 指定账户密码数据库,这里采用先前生成的puredb数据库
& 是让 pure-ftpd在后台运行

6.执行 ps -ef | grep pure-ftpd 可以看得到ftp 服务器已经启动了。
root 25839 20560 0 10:03 pts/0 00:00:00 pure-ftpd (SERVER)
root 25841 20560 0 10:03 pts/0 00:00:00 grep pure-ftpd

7. 一点小问题
服务器启动后,在windows 资源管理器中输入ftp://widebright@服务器IP 这样的语句已经
可以访问到刚才创建的ftp服务器了。下载也很正常,可就是不能上传。
用户文件权项问题, 这个和关联的linux用户的文件夹权项有关,
我采用的是ftpftp用户所以执行
#chown ftpftp /usr/local/nginx/html
就可以上传文件了。
如果不能上传文件的话用ls -l 来看看你的linux用户有没有相应的文件夹的写权限,必要的时候采用chown chmod命令修改。

附上网上找的pure-pw command not found的错误解决方法,这里没有测试
1. 报没找到命令是因为pure-pw所在的目录没有加到PATH环境变量中。
解决办法有两个:
a)把这个目录加到PATH环境变量里
比如 export PATH=$PATH:/usr/local/pureftpd/bin,想永久生效的话得修改用户的profile
2)用绝对路径访问pure-pw
比如 /usr/local/pureftpd/bin/pure-pw
附上用户删除命令:
#/usr/local/pureftp/bin/pure-pw userdel widebright222 -f /usr/local/pureftp/pure-ftpd.passwd
附上用户宿主目录修改命令
# /usr/local/pureftp/bin/pure-pw usermod widebright -d 新目录 -f /usr/local/pureftp/pure-ftpd.passwd

2. 确认pureftpd使用的是这个配置文件,确认修改配置文件以后重新启动pureftpd
安装后nginx或apache改变ftpftp的宿主目录,以及widebright上传路径,
改变ftpftp用户的宿主目录为/usr/local/nginx/html ,这里ningx的站点目录为/usr/local/nginx/html/
#usrmod -d /usr/local/nginx/html ftpftp
改变上传路径
# /usr/local/pureftp/bin/pure-pw --help 查看help看到修改用户上传路径用pure-pw usrmod -d
# /usr/local/pureftp/bin/pure-pw usermod widebright -d 新目录 -f /usr/local/pureftp/pure-ftpd.passwd
然后重启pure-ftp, 不知怎么重启, ps查看pure-ftp的进程结束掉,然后
#pure-pw mkdb /usr/local/pureftp/pure-ftpd.pdb -f /usr/local/pureftp/pure-ftpd.passwd 重新生成数据库密码
# /usr/local/pureftp/sbin/pure-ftpd -l puredb:/usr/local/pureftp/pure-ftpd.pdb & 再启动

]

你可能感兴趣的:(ftp,pureftp)