Ubuntu Vsftpd 配置

一直想在Ubuntu下设置FTP服务器,但一直就没成功。
今天有些时间,经过测试终于成功了。
由于在linux中的ftp软件很多,这里我只介绍vsftpd。

1. 安装vsftpd

frank@frank-desktop:/etc/apt$ sudo apt-get install vsftpd

2. 配置

以下是我的配置,我只介绍我配置的主要参数,带“#”号的配置没有介绍,以后如果应用到其他配置,我会更新此文章。
root@frank-desktop:~# vim /etc/vsftpd.conf

listen=YES
!—独立模式,具体功能不知道,最好开启
local_enable=YES
!—远程用户可以使用本地账号(非ftp账号)登陆ftp服务器
write_enable=YES
!—开启写权限
connect_from_port_20=YES
!—用port 20传送数据
chroot_list_enable=YES
!—开启本地限制,限制本地用户在本地目录中
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd.chroot_list
!—如果本地限制打开了,再打开chroot_list,那么在list中的用户将可以游览任何目录,不被列入的用户将被锁在自己的目录下,不能游览其他的目录。如果你想让本地用户不被锁住,只要手动把用户名添加到chroot_list中就可以了。这个list是手动添加的,不是自动生成的。

2012-2-11 更新:
改变vsftpd的默认路径,需要在vsftpd.conf中增加以下参数
local_root=/ftp/
!—表示使用本地用户登录到ftp时的默认目录
anon_root=/ftp/
!—表示匿名用户登录到ftp时的默认目录
root@frank-desktop:~# service vsftpd restart
!—重启服务
另外如果上面提到的chroot_list_file已经开启了,那么必须手动建立这个文件,用户才能访问ftp服务器,因为不管用户有没有被锁在自己的路径下,都会去确认这个文件。

3. 问题

启动后发现能游览,而且在“/home/frank”目录中可以获得所有权限,包括删除添加。
但是其他的目录(如“/home/ftp”)不能上传,只能下载。
上传、创建文件或目录时总是提示:
550 Remove directory operation failed.

root@frank-desktop:/home# ls -l
drwxr-xr-x 42 frank frank   4096 2009-08-04 14:54 frank
drwxr-xr-x  4 root  nogroup 4096 2009-08-04 15:14 ftp

4. 解决

经过研究,如果你想在某个文件夹中获得上传及修改的权限,那么需要把此文件夹的权限设置成777,这样就可以了。关于777是怎么计算出来的,可以参考《Ubuntu 自动加载NTFS分区》中的内容。

但为什么把权限设置成跟“/home/frank”文件夹的权限一样,结果还是不行呢?

在 Linux/Unix 中,档案的权限分为三级 : 档案所有者、群组、其他。
因此登陆ftp用的账号是frank本地账号,那么他会应用frank的权限;所以对于“/home/frank”文件夹,他只关心所有者的权限,所以他有写的权限。

对于“/home/ftp”文件夹,它属于root用户,并且没有组,所以他只关心其他的权限,由于其他的权限是5,没有执行,所以不能进行写的权限。

可以有两种方法解决不能上传的问题:

1. 设置文件夹“其他”的权限

root@frank-desktop:/home# chmod 757 ftp
root@frank-desktop:/home# ls -l
drwxr-xr-x 42 frank frank   4096 2009-08-04 14:54 frank
drwxr-xrwx  4 root  nogroup 4096 2009-08-04 15:14 ftp

2. 更改ftp文件夹得所有者

root@frank-desktop:/home# chown frank /home/ftp
root@frank-desktop:/home# ls -l
drwxr-xr-x 42 frank frank   4096 2009-08-04 14:54 frank
drwxr-xr-x  4 frank nogroup 4096 2009-08-04 15:14 ftp

另外扩展下chown的用法,下面是更改所属组的例子。
冒号前面是所有者,冒号后面是组:

root@frank-desktop:/home# chown frank:frank /home/ftp/
root@frank-desktop:/home# ls -l
drwxr-xr-x 42 frank frank 4096 2009-08-04 14:54 frank
drwxr-xr-x  4 frank frank 4096 2009-08-04 15:14 ftp

另外有一个“小插曲”,就是当我把ftp用户删除后,登陆ftp会提示以下错误:
vsftpd: cannot locate user specified in ‘ftp_username’:ftp
Unable to make a connection. Please try again.

确认后vsftp默认的缺省用户是ftp,我把ftp删了,他就找不到了,需要在config文件中加入以下配置就ok了:
ftp_username=nobody

本文出自 Frank's Blog

版权声明:


本文链接:Ubuntu Vsftpd 配置
版权声明:本文为原创文章,仅代表个人观点,版权归 Frank Zhao 所有,转载时请注明本文出处及文章链接
你可以留言,或者trackback 从你的网站

No Responses to “Ubuntu Vsftpd 配置”

  1. Magento小工说道:

    今天正好装两个vsftp服务器,总结的好!

留言哦

blonde teen swallows load.xxx videos