工作需要一个ftp服务器(linux),于是蛋疼一下。
vsftp:常用的选择之一,但依赖libcap,libcap又依赖系统头文件,于是抛弃
pureftp:比较轻量级,用之
操作方式:
-------------------------------------------------------------------
1. 下载 最好切换到安装的目录,地址可到官方找最新的
如下载 pure-ftpd-1.0.36.tar.gz
#wget http://download.pureftpd.org/pub/pure-ftpd/releases/pure-ftpd-1.0.36.tar.gz
2. 安装
下载下来之后 解压文件
#tar xzvf pure-ftpd-1.0.32.tar.gz
cd 进解压根目录
#cd pure-ftpd-1.0.32
./configure编译
#./configure --prefix=/usr/local/pureftp --with-everything
注:
--with-eyerything 是安装所有功能
--with-language=simplified-chinese 是采用中文作为提示语言,默认是英文,
--prefix是安装的目标目录
若把ftp账户信息保存在mysql中要在这里设定,还有很多选项,可以查看目录下的README文件,这里安装时就没有指定--with-language。
编译安装:
#make
#make install
3. 配置 FTP登录账户
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在后台运行
-S 可指定 ip和端口
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
注意事项
----------------------
目录权限
上传目录的 用户:用户组 需改为ftp用户:用户组,否则无法上传
文件权限
默认上传的文件,权限是只读,如果要支持直接编辑,需要可写权限,暂时没找到设置方法