图文详解Ubuntu搭建Ftp服务器的方法(包成功)

一、今天下午由于课程的要求不得已做了Ubuntu搭建Ftp服务器的实验,但是实验指导书还是N年前的技术,网上搜了一大把,都是模模糊糊的!

在百般困难中终于试验成功,特把经验分给大家 希望大家少走弯路!

二、详细步骤如下:

(1)首先打开终端进入root模式下(在终端中输入:sudo su 回车 提示输入密码  输入密码即可);

(2)安装vsftpd软件(首先要联网,或者通过新立德软件安装!卸载软件命令:sudo apt-get remove vsftpd)

<span >命令:sudo apt-get install vsftpd</span>

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

(3)安装成功之后,默认的会在 文件系统下的srv 目录下创建一个ftp文件(和home在同一级目录下的),这里就是ftp服务器的默认文件夹!

(4)在有一些文档上说的是在ftp服务器自动创建的目录是在home目录下的ftp文件夹,但是我始终没有找到(一般home目录下是用户的目录),自己创建的在访问ftp的时候也是没有找到!

(5)向服务器目录添加文件夹和文件,首先在srv/ftp/下创建一个文件夹test(手动无法创建,只能通过命令实现!)

命令:mkdir   /srv/ftp/test

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

得到创建好的文件夹:

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

多创建几个目录仅用于测试!

(6)在test文件夹中创建一个文件:touch     /srv/ftp/test/1.txt 文件

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

(7)编辑该1.txt文件:(由于权限的管理,需要利用root模式更改文件内的内容!)

sudo gedit /srv/ftp/test/1.txt    会弹出一个记事本文件 是root权限下打开的才可以修改的|!随便加些内容

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

(8)为了说明一个命令,重启一下!

命令是:sudo /etc/init.d/vsftpd restart

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

(9)查看是否成功 找到Ubuntu的IP地址,在地址栏中访问  我的是:ftp://192.168.136.130/   或者是ftp://localhost,以下是截图:

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

进入test找到1.txt文件 点击进入!

图文详解Ubuntu搭建Ftp服务器的方法(包成功)

(10)ok!到此完成!

三、上述中知识介绍了一般默认的配置,我们通常是需要根据自己的需求配置的,以下是一些常见的配置!

如需修改的话还是需要在root权限下修改 使用命令:sudo      gedit       /etc/vsftpd.conf   

(1)匿名用户相关设置

anonymous_enable=YES     ,将YES改为NO, 禁止匿名用户登陆

#anon_mkdir_write_enable=YES    ,将#注释去掉,允许匿名用户创建目录

#non_upload_enalbe=YES   ,将#去掉,允许匿名用户上传

anon_world_readable_only=YES  ,允许匿名用户下载,默认是禁止的,这个可以自行添加。

Anon_other_write_enable=YES  ,将其设为YES的话,就除了上传和创建目录外,还可以重命名,删除文件,默认是NO

no_anon_password=NO     ,将其设为YES,匿名用户不会查询用户密码直接登陆。

ftp_username=ftp  ,匿名用户登陆系统的账号默认为ftp,此项最好不要改;

chroot_local_user=YES #把本地用户限制在自己的home文件夹中,这样子登录之后就不能访问自己home之外的文件了,这样子是出于安全上的考虑

anon_root=/var/ftp/anon #指定匿名登录后的根文件夹,也就是对于匿名用户,会把/var/ftp/anon映射为它的根目录

(2)FTP服务端口的指定

listen_port=8021  ,指定命令通道为8021,默认为21

listen_data_port=8020  ,指定数据通道为8020,默认为20

(3)上传模式的设置

pasv_enable=YES         ,是否允使用被动模式,默认是允许的。

pasv_min_port=10000   ,指定使用被动模式时打开端口的最小值

pasv_max_port=10004 ,指定使用被动模式时打开端口的最大值。

(4)Vsftp服务器指定IP地址

listen_address=192.168.0.21 ,  指定FTP,IP地址

注:只有当vsftp运行于独立模式时才允许使用指定IP,如果在/etc/xinetd.d目录下已经建立了vsfpd文件,就要将该文件中的disable设置为yes,方可。

(5)锁定用户,禁止用户离开用户主目录

chroot_local_user=YES ,将其设为YES,就锁定在用户主目录,设为NO,可以切换

将指定用户设置为锁定用户主目录:

#chroot_list_enable=YES #chroot_list_file=/etc/vsftpd.chroot_list

将其改为如下:

chroot_list_enable=NO chroot_list_file=/etc/vsftpd/vsftpd.chroot_list

将上面保存,再做如下操作:

#touch /etc/vsftpdvsftpd.chroot_list #vi /etc/vsftpd/vsftpd.chroot_list ,在该文件中加入用户名单,如:netseek_com

(6)vsftpd服务器的流量控制

max_clients=100 ;允许的最大连接数,定义为100,默认为0,表没有限制

max_per_ip=5 ;每个IP允许的连接数,0表没有限制,需要运行于独立模式方可

anon_max_rate=50000 ;匿名用户最大带宽,单位为bps

local_max_rate=200000  ;系统用户最大带宽

(7)vsftpd定制欢迎信息

目录说明设置

#vi /etc/vsftpd.conf #dirmessage_enable=YES,前的#去掉。

然后我们定制一个.message,写上你想写的东西,然后把这个文件复制到各个用户的家目录中,就OK。

(9)vsftpd系统欢迎消息设置

ftpd_banner=Welcome to ftp.netseek.com , Yeah!!! 

系统欢迎消息文件设置

banner_file=/etc/vsftpd/welcome   与ftpd_banner相类似,不同之处在于,banner_file指定欢迎文件。

四、创建用户

但这样是不能上传文件的。因为这是匿名用户,当前目录所有者是root用户; 真的要上传文件在该目录下建立一个文件夹如名字是upload,

$ sudo mkdir /srv/ftp/upload $ sudo chown ftp:root /srv/ftp/upload

这个时候可以传文件到upload目录,但根目录还是不能上传文件,这是匿名用户,如果不是匿名用户就不存在这个问题。

1). 修改配置文件/etc/vsftpd.conf

anonymous_enable=NO local_enable=YES write_enable=YES chroot_local_user=YES

2). 创建本地用户

$ sudo useradd ftpuser -m $ sudo passwd ftpuser

便可用ftpuser登录FTP了。

6. 如果出现错误:500 OOPS: vsftpd: refusing to run with writable anonymous root 

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。