vsftpd服务器的安装和配置

vsftpd服务器的安装和配置

在linux或者centOS下类似。
一直想在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是手动添加的,不是自动生成的。
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

  1. 解决
    经过研究,如果你想在某个文件夹中获得上传及修改的权限,那么需要把此文件夹的权限设置成777,这样就可以了。关于777是怎么计算出来的,可以参考《Ubuntu 自动加载NTFS分区》中的内容。
    但为什么把权限设置成跟“/home/frank”文件夹的权限一样,结果还是不行呢?
    在 Linux/Unix 中,档案的权限分为三级 : 档案所有者、群组、其他。
    因此登陆ftp用的账号是frank本地账号,那么他会应用frank的权限;所以对于“/home/frank”文件夹,他只关心所有者的权限,所以他有写的权限。
    对于“/home/ftp”文件夹,它属于root用户,并且没有组,所以他只关心其他的权限,由于其他的权限是5,没有执行,所以不能进行写的权限。
    可以有两种方法解决不能上传的问题:
  2. 设置文件夹“其他”的权限

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

  1. 更改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”

转载[转载日期2016-09-27].
http://www.server110.com/vsftpd/201404/10330.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
安装配置vsftpd服务器并设置虚拟用户的步骤如下: 1. 安装vsftpd服务器: 在Ubuntu终端中运行以下命令安装vsftpd服务器: ``` sudo apt-get update sudo apt-get install vsftpd ``` 2. 配置vsftpd服务器: 打开vsftpd配置文件: ``` sudo nano /etc/vsftpd.conf ``` 3. 修改以下配置项: - 启用虚拟用户功能,将以下行取消注释并修改为: ``` virtual_use_local_privs=YES guest_enable=YES guest_username=ftp user_sub_token=$USER local_root=/home/ftp/$USER chroot_local_user=YES hide_ids=YES ``` - 禁用名访问,将以下行取消注释并修改为: ``` anonymous_enable=NO ``` - 允许写入权限,将以下行取消注释并修改为: ``` write_enable=YES local_umask=022 file_open_mode=0777 ``` 4. 保存并关闭文件。 5. 创建虚拟用户: 创建一个系统用户用于管理虚拟用户: ``` sudo adduser ftp ``` 6. 创建虚拟用户配置文件: 创建一个文件来存储虚拟用户的用户名和密码: ``` sudo nano /etc/vsftpd/virtual_users.txt ``` 7. 在文件中添加虚拟用户的用户名和密码,每行一个用户,格式为`用户名:密码`,例如: ``` user1:password1 user2:password2 ``` 8. 保存并关闭文件。 9. 生成虚拟用户数据库文件: 运行以下命令生成虚拟用户数据库文件: ``` sudo db_load -T -t hash -f /etc/vsftpd/virtual_users.txt /etc/vsftpd/virtual_users.db ``` 10. 设置权限: 运行以下命令设置虚拟用户数据库文件的权限: ``` sudo chmod 600 /etc/vsftpd/virtual_users.db ``` 11. 重启vsftpd服务: 运行以下命令重启vsftpd服务以使配置生效: ``` sudo service vsftpd restart ``` 现在,您已经成功安装配置vsftpd服务器,并设置了虚拟用户。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值