如何在 linux 中搭建 FTP 服务

alimiracle 的头像

·

·

·

13,616 次阅读

在本教程中,我将会介绍如何搭建你自己的FTP服务。但是,首先我们应该来的学习一下FTP是什么。

FTP是什么?

FTP 文件传输协议 File Transfer Protocol 的缩写。顾名思义,FTP用于计算机之间通过网络进行文件传输。你可以通过FTP在计算机账户间进行文件传输,也可以在账户和桌面计算机之间传输文件,或者访问在线软件归档。但是,需要注意的是多数的FTP站点的使用率非常高,可能需要多次重连才能连接上。

FTP地址和HTTP地址(即网页地址)非常相似,只是FTP地址使用ftp://前缀而不是http://

FTP服务器是什么?

通常,拥有FTP地址的计算机是专用于接收FTP连接请求的。一台专用于接收FTP连接请求的计算机即为FTP服务器或者FTP站点。

现在,我们来开始一个特别的冒险,我们将会搭建一个FTP服务用于和家人、朋友进行文件共享。在本教程,我们将以vsftpd作为ftp服务。

VSFTPD是一个自称为最安全的FTP服务端软件。事实上VSFTPD的前两个字母表示“ 非常安全的 very secure ”。该软件的构建绕开了FTP协议的漏洞。

尽管如此,你应该知道还有更安全的方法进行文件管理和传输,如:SFTP(使用OpenSSH)。FTP协议对于共享非敏感数据是非常有用和可靠的。

使用 rpm 安装VSFTPD:

你可以使用如下命令在命令行界面中快捷的安装VSFTPD:

dnf -y install vsftpd

使用 deb 安装VSFTPD:

你可以使用如下命令在命令行界面中快捷的安装VSFTPD:

sudo apt-get install vsftpd

在Arch 中安装VSFTPD:

你可以使用如下命令在命令行界面中快捷的安装VSFTPD:

sudo pacman -S vsftpd

配置FTP服务

多数的VSFTPD配置项都在/etc/vsftpd.conf配置文件中。这个文件本身已经有非常良好的文档说明了,因此,在本节中,我只强调一些你可能进行修改的重要选项。使用man页面查看所有可用的选项和基本的 文档说明:

man vsftpd.conf

根据文件系统层级标准,FTP共享文件默认位于/srv/ftp目录中。

允许上传:

为了允许ftp用户可以修改文件系统的内容,如上传文件等,“write_enable”标志必须设置为 YES。

write_enable=YES

允许本地(系统)用户登录:

为了允许文件/etc/passwd中记录的用户可以登录ftp服务,“local_enable”标记必须设置为YES。

local_enable=YES

匿名用户登录

下面配置内容控制匿名用户是否允许登录:

# 允许匿名用户登录
anonymous_enable=YES
# 匿名登录不需要密码(可选)
no_anon_password=YES
# 匿名登录的最大传输速率,Bytes/second(可选)
anon_max_rate=30000
# 匿名登录的目录(可选)
anon_root=/example/directory/

根目录限制(Chroot Jail)

( LCTT 译注:chroot jail是类unix系统中的一种安全机制,用于修改进程运行的根目录环境,限制该线程不能感知到其根目录树以外的其他目录结构和文件的存在。详情参看chroot jail

有时我们需要设置根目录(chroot)环境来禁止用户离开他们的家(home)目录。在配置文件中增加/修改下面配置开启根目录限制(Chroot Jail):

chroot_list_enable=YES 
chroot_list_file=/etc/vsftpd.chroot_list

“chroot_list_file”变量指定根目录限制所包含的文件/目录( LCTT 译注:即用户只能访问这些文件/目录)

最后你必须重启ftp服务,在命令行中输入以下命令:

sudo systemctl restart vsftpd

到此为止,你的ftp服务已经搭建完成并且启动了。


via: http://itsfoss.com/set-ftp-server-linux/

作者:alimiracle 译者:cvsher 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

8 条回复

  1. 来自浙江杭州的 Chrome 45.0|GNU/Linux 用户 的头像
    来自浙江杭州的 Chrome 45.0|GNU/Linux 用户

    arch 的安装方法搞错了

    来自杭州
  2. 来自广东广州的 Chrome 45.0|GNU/Linux 用户 的头像
    来自广东广州的 Chrome 45.0|GNU/Linux 用户

    arch中应该是pacman而不是apt-get吧,英文原文没错,翻译时错了。

    来自广州
  3. linux [Chrome 45.0|Mac 10.10] 的头像
    linux [Chrome 45.0|Mac 10.10]

    谢谢提醒~

    来自北京
  4. 不简单 [Chrome 31.0|Windows 7] 的头像
    不简单 [Chrome 31.0|Windows 7]

    请问去哪下载vsftp服务安装包呢?

    来自郑州
  5. linux [Chrome 45.0|Mac 10.10] 的头像
    linux [Chrome 45.0|Mac 10.10]

    一般来说,你的发行版的软件库里面都有的。使用你的发行版的安装命令即可安装。

    来自北京
  6. 不简单 [Chrome 31.0|Windows 7] 的头像
    不简单 [Chrome 31.0|Windows 7]

    好的! 等下我看看,谢谢了!

    来自郑州
  7. neteric [Firefox 41.0|Windows 10] 的头像
    neteric [Firefox 41.0|Windows 10]

    看似简单,实际上不是那么容易的服务

    来自大连
  8. xidan [Sogou Explorer 2|Windows 7] 的头像
    xidan [Sogou Explorer 2|Windows 7]

    请问,怎么分配权限呢?
    在FTP目录下,我设置几个文件夹,有一个超级用户权限可以查看所有文件内容;针对某一文件夹,有一个用户权限可以实现对文件内容进行修改,另一用户只能看,不能随意改动。
    这个容易实现吗,求指教,非常感谢。

    来自天津

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注