ftp服务器搭建

工作需要一个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


注意事项

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

  1. 目录权限

    上传目录的 用户:用户组 需改为ftp用户:用户组,否则无法上传

  2. 文件权限

    默认上传的文件,权限是只读,如果要支持直接编辑,需要可写权限,暂时没找到设置方法



你可能感兴趣的:(ftp服务器搭建)