一直想在Ubuntu下设置FTP服务器,但一直就没成功。
今天有些时间,经过测试终于成功了。
由于在linux中的ftp软件很多,这里我只介绍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是手动添加的,不是自动生成的。
启动后发现能游览,而且在“/home/frank”目录中可以获得所有权限,包括删除添加。
但是其他的目录(如“/home/ftp”)不能上传,只能下载。
上传、创建文件或目录时总是提示:
“550 Remove directory operation failed.”
经过研究,如果你想在某个文件夹中获得上传及修改的权限,那么需要把此文件夹的权限设置成777,这样就可以了。关于777是怎么计算出来的,可以参考《Ubuntu 自动加载NTFS分区》中的内容。
但为什么把权限设置成跟“/home/frank”文件夹的权限一样,结果还是不行呢?
在 Linux/Unix 中,档案的权限分为三级 : 档案所有者、群组、其他。
因此登陆ftp用的账号是frank本地账号,那么他会应用frank的权限;所以对于“/home/frank”文件夹,他只关心所有者的权限,所以他有写的权限。
对于“/home/ftp”文件夹,它属于root用户,并且没有组,所以他只关心其他的权限,由于其他的权限是5,没有执行,所以不能进行写的权限。
可以有两种方法解决不能上传的问题:
1. 设置文件夹“其他”的权限
2. 更改ftp文件夹得所有者
另外扩展下chown的用法,下面是更改所属组的例子。
冒号前面是所有者,冒号后面是组:
另外有一个“小插曲”,就是当我把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”