Vsftpd的安装和配置。

需要使用ftp来做图片服务器,就选用了vsftpd来实现。安装起来比较简单,但是在过程中出现了几个问题,为了防止以后使用,就记录一下整个过程。


安装

首先本人使用的是ubuntu系统,安装vsftpd直接使用命令即可:

sudo apt-get install vsftpd

安装完成之后需要查看对应的端口是否开放了,ftp使用的是21端口:

netstat -npltu | grep 21

这里写图片描述


登陆。

等待安装完成之后,可以直接在本地进行登陆,登陆的命令如下:

ftp localhost

然后出出现输入账号密码的界面,由于本人使用的是用来学习的虚拟机,所以也没有必要设置多个账号,习惯性直接使用root从而减少一些权限的问题。

但是当我输入root的账号和对应的密码之后却出现了如下的问题:

这里写图片描述

问题也就是:

331 Please specify the password.
530 Login incorrect.

说我登陆不正确,可是我能够确定账号和密码都输入无误的,然后就查了查,在网上发现有人也出现了同样的问题,但是他的解决办法是直接删除/etc/pam.d/vsftpd,里面的解释是:

因为ubuntu启用了PAM,所以在用到vsftpd的时候需要用到/etc/pam.d/vsftpd这个文件,还说默认源码安装的时候不会有这个文件。所以才会导致除了匿名用户外本地用户无法登陆,然后就删除了这个文件,连接ftp出现 331 Please specify the password 的解决办法

我试了一下,将该文件删除之后确实能够登陆的。但是后来想想不太对,既然是etc下面的文件,也就是配置文件,那么它肯定有存在的道理,也不应该无缘无故的删除。然后又卸载重装,重新审视该问题。

现在我们知道了该问题是由PAM导致的,但是什么PAM本人还不太清楚,然后大概的查了查资料,可以参考这篇文章:PAM-Linux可插拔认证模块的基本概念与架构

从中可以直到PAM的全程是:可插拔认证模块(Pluggable Authentication Module–PAM)机制,可以让用户轻易在应用程序中插入新的认证模块或替换原先的组件。

那么现在的思路就清楚了,在使用Vsftpd的时候,ubuntu会启用PAM模块(至于使用源码安装是否会启用PAM模块,本人并没有实验,因此不能确认),使用新的认证机制。然而使用了这个认证机制才导致了使用root用户无法登陆,那么我们就应该查看一下这个认证机制究竟做了什么,查看/etc/pam.d/vsftpd文件:

这里写图片描述

发现其中deny(拒绝),以及一个文件,尝试这查看这个/etc/ftpusers这个文件:

这里写图片描述

对了,问题就在这,不允许访问ftp的列表中竟然有root,然后将root删除掉之后重新登陆,已经能够登陆成功了:

这里写图片描述

而且还可以通过PAM给ftp配置虚拟用户。这篇文章关于vsftpd的介绍很全面:Vsftpd,其中也有提到上述root用户的问题,可惜是在解决之后才发现的,不然能剩下不少时间。


使用FileZilla传输文件。

既然解决了root登陆的问题,那么接下来就开始使用vsftpd了,连接ftp的客户端使用的是FileZilla。

此时已经能够连接成功了,双击本地的文件进行上传,但是上传文件的时候却又出现了问题:

这里写图片描述

发现传输失败了,此时还需要配置一下/etc/vsftpd.conf的一些内容,将有关文件传输配置开启:

这里写图片描述

配置完成之后需要保存,并且重启vsftpd:

service vsftpd restart

重启完成之后,此时就能够正常的上传和下载文件了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值