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

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

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

二、详细步骤如下:

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

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

<span style="font-size:14px;">命令:sudo apt-get install vsftpd</span>

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

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

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

命令:mkdir   /srv/ftp/test

得到创建好的文件夹:

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

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

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

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

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

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

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

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

(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

这表示ftp用户的家目录的权限不对,这个目录的权限是不能打开所有权限的;是运行了chmod 777 /srv/ftp所致;如果没有ftp用户这个家目录,当然您要自己建一个;

FTP用户的家目录是不能针对所有用户、用户组、其它用户组完全开放的;解决办法如下:

# chown root:root /srv/ftp
# chmod 755 /srv/ftp

7. 防火墙打开相应的端口21,20

8. /etc/init.d/vsftpd restart 重启服务

五、各用户的解释

下面就vsftpd支持三类用户加以说明:

  • 1.匿名用户,也就是不需要输入密码就可登录ftp服务器的用户,这个用户名通常是ftp或anonymous; 与匿名用户有关的设置多以 anon_选项开头。
  • 2.本地用户,也就是你Linux系统上可登录到系统的用户,这些用户是在系统上实实在在存在的用户。通常会有自己的home,shell等。与本地用户有关的设置多以local_开头或包含local_的选项。
  • 3.虚拟用户,只对ftp有效的用户。这些用户不可以登录Linux系统,只可以登录ftp服务器。其实就是一个本地用户映射成多个只对ftp服务器有效的虚拟用户。虚拟用户可以有自己的ftp配置文件,因此通常利用虚拟用户来对ftp系统的不同用户制定不同的权限,以达到安全控制的目的。与虚拟用户有关的设置以guest_开头。

如果你只是想用ftp实现对自己的共享,你可以开启本地用户;

如果你想对很多人共享,那你可以用匿名用户;

如果你需要针对不同的用户群给予不同的权限,那你就要设置更复杂的虚拟用户了。

mkdir 目录名         => 创建一个目录
rmdir 空目录名      => 删除一个空目录
rm 文件名 文件名   => 删除一个文件或多个文件
rm –rf 非空目录名 => 删除一个非空目录下的一切
touch 文件名        => 创建一个空文件

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • PythonWeb项目Django部署在Ubuntu18.04腾讯云主机上

    Django2.1 + Python3.6 + nginx + uwsgi 部署到Ubuntu18.04 材料准备 准备一个Django项目准备一台Ubuntu18.04的主机 ssh连接到主机(腾讯云) Mac直接在bash中输入ssh root@你的主机ip Windows请下载ssh远程连接工具例如Putty 腾讯云默认不能以root身份登录,请使用以下方式登录 $ ssh -q -l ubuntu -p 22 你的主机ip 配置Python3.6环境 Ubuntu18.04已经默认安装了

  • Linux-ubuntu16.04 Python3.5配置OpenCV3.2的方法

    1.OpenCV下载 首先创建一个空的文件夹,进入文件夹执行如下命令,如我创建的文件夹是opencv-python cd opencv-python git clone https://github.com/opencv/opencv.git 也可以直接进入网址OpenCV_Download下载 使用git下载后应有一个名字为opencv的文件夹,进入文件夹执行如下命令: cd opencv mkdir build cd build 2.编译opencv源码 使用cmake编译opencv源码,

  • Ubuntu18.04安装opencv 3.2.0的解决方法

    下载opencv.zip 要提前安装依赖项. 先更新一下下载源.用17.04 的源可以解决在18.04中找不到libjasper.dev的问题. ref https://stackoverflow.com/questions/43484357/opencv-in-ubuntu-17-04 libjasper-dev无法安装 errorE: unable to locate libjasper-dev 解决方法 sudo add-apt-repository "deb http://securit

  • ubuntu下没有中文输入法的解决办法

    ubuntu下没有中文输入法的解决办法! 我们在安装虚拟机或者ubuntu系统的时候,常见的是尽管是中文版本的但却没有中文输入法,确实是一件很恼火的事情! 我自己也亲身经历过,特此给大家提供一种方法,很好用的! 我们在安装ubuntu系统的时候,最常见也是我们大家默认的是不会安装在线更新什么的,因为这样下来计费时间,还是费时间!所以就没有更新! 所以当出现,没有中文输入法的时候,我们第一个要做的就是: (1)更新系统软件,这一点不做解释,我们需要选取最近的节点作为我们更新软件的服务器: (2)在

  • ubuntu下编译安装opencv的方法

    简易安装opencv2: conda install --channel https://conda.anaconda.org/menpo opencv 或: sudo apt-get install libopencv-dev python-opencv 简易安装opencv3: pip install opencv-python 或: pip install opencv-python==3.1.0 简易安装方式是从库中安装编译好了的Opencv,这种安装方式简单方便,缺点是容易在使用中出现

  • ubuntu14.04安装opencv3.0.0的操作方法

    1.安装依赖项 直接编译安装opencv一般会报错,依赖工具需要先安装. $ sudo apt-get install build-essential cmake libopencv-dev libgtk2.0-dev pkg-config python-dev python-numpy 2.下载opencv3(两个版本任选其一) $ mkdir ~/opencv $ cd ~/opencv $ wget https://github.com/Itseez/opencv/archive/3.0.

  • Ubuntu16.04/树莓派Python3+opencv配置教程(分享)

    无论是Windows.Linux.还是树莓派 .配置python3的opencv环境都是让人头大的一件事情,尤其是许多人用pip安装以后,发现opencv虽然装上了,但是却装在了系统原生的python2下. 笔者也是经历过很多次失败之后,才安装成功. 本文采用编译的方法配置opencv,每一步都有ubuntu和树莓派的分别配置,由于两个系统极其相似(可以说是基本一样),所以并在一文详解. 一般来说,只要按照步骤去安装配置,就不会出错.废话不多说,开始表演! step1:准备工作 1.ubuntu

  • Ubuntu 17.04系统下源码编译安装opencv的步骤详解

    前言 本文主要针对Ubuntu 17.04版本下,opencv进行源码编译安装.开发环境主要针对python 对 openCV库的调用.下面话不多说了,来一起看看详细的介绍: 一.安装 gcc cmake 编译环境 sudo apt-get install build-essential pkg-config cmake cmake-gui 本文提供两种源码编译方式,一种是cmake命令,另一种是通过图形界面的cmake-gui进行编译 该版本系统ubuntu已经自带python 2.7 和 p

  • Ubuntu中Opencv的安装使用教程

    前言 OpenCV为基于BSD许可(开源)发行的跨平台计算机视觉库,可运行在Linux.Windows和Mac OS上.它轻量级而且高效,提供了Python.Ruby.MATLAB等语言接口,实现了图像处理和计算机视觉方面的很多通用算法. OpenCV不仅在进行软件开发的过程中需要用到,而且他也是很多开源软件的运行依赖,所以安装一个Opencv就很有必要了,即使自己本身并不想学习使用. 安装 以下主要是从百度上找到的可用方法: 安装运行依赖 $ sudo apt-get install libq

  • Ubuntu14.04 opencv2.4.8和opencv3.3.1多版本共存的实现方法

    首先,由于本人使用了ROS,因此在安装ROS的时候安装了ros-indigo-destop-full顺便安装了版本2.4.8的opencv,因为ROS里面的一些文件需要依赖于该版本的opencv,例如cv_bridge和image_pipeline.所以卸掉opencv2.4.8再装opencv3.3(因为有些代码需要用到opencv3)貌似不明智.故我们在原有的opencv2.4.8的版本基础上安装opencv3.3,因此这里涉及到了ubuntu多版本opencv共存问题. 之前安装了CUDA

随机推荐