云服务器ECS下的FTP服务的安装配置与使用

简介

FTP 是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为“文传协议”。用于Internet上的控制文件的双向传输。同时,它也是一个应用程序(Application)。基于不同的操作系统有不同的FTP应用程序,而所有这些应用程序都遵守同一种协议以传输文件。
互联网上提供文件存储和访问服务的计算机,他们依照的是FTP协议提供服务!支持FTP协议的服务器就是FTP服务器!FTP协议提供存储和传输服务的一套协议。
下载"(Download)和"上传"(Upload)。”下载”文件就是从远程主机拷贝文件至自己的计算机上;”上传”文件就是将文件从自己的计算机中拷贝至远程主机上。用Internet语言来说,用户可通过客户机程序向(从)远程主机上传(下载)文件。

工作原理

FTP采用客户端/服务端的工作模式(C/S结构),通过TCP协议建立客户端和服务器之间的连接,但与其他大多数应用协议不同,FTP协议在客户端和服务端之间建立了两条通信链路,分别是控制链路和数据链路,其中,控制链路负责FTP会话过程中FTP命令的发送和接收,数据链路则负责数据的传输。
FTP会话包含了两个通道,控制通道和数据通道,FTP的工作有两种方式,一种是主动模式,一种是被动模式,以FTPServer为参照物,主动模式,服务器主动连接客户端传输,被动模式,等待客户端的的连接 。
(无论是主动模式还是被动模式,首先的控制通道都是先建立起来的,只是在数据传输模式上的区别)。

本教程主要介绍在Windows server 2008 R2和CentOS 7.2的系统环境上手动部署。

Windows server 2008 R2

安装前准备

选用windows server 2008 R2 企业版 64位中文版的系统,阿里云在公共镜像中提供了该系统镜像,用户可直接在控制台中更换此系统。并通过远程链接进入到系统中。

安装FTP服务

开始>管理工具>服务管理器。

安装IIS/FTP角色。

打开服务器管理器,找到添加角色,然后点击,弹出添加角色对话框,选择下一步。

选择Web服务器(IIS),然后选择FTP服务,直到安装完成。

进入IIS管理器。

右键网站出现添加“FTP站点”就表示FTP服务安装成功。

创建Windows用户名和密码,用于FTP使用。

开始>管理工具>服务器管理器,添加用户,如下图:本实例使用ftptest。

在设置密码时要采用大写字母加小写字母加数字的组合,否则会显示无法通过密码策略。

在服务器磁盘上创建一个供FTP使用的文件夹,创建FTP站点,指定刚刚创建的用户ftptest,赋予读写权限。

填写FTP站点名称与默认目录。

绑定21端口(也可自行设置)。

授权之前创建的ftptest用户允许访问和读写权限。

完成后看到设置的FTP站点。

客户端测试。直接使用ftp://服务器ip地址:ftp端口(如果不填端口则默认访问21端口),如图。弹出输入用户名和密码的对话框表示配置成功,正确的输入用户名和密码后,即可对FTP文件进行相应权限的操作。

登录成功。

CentOS 7.2

安装前准备

选用CentOS 7.2 64位的系统,阿里云在公共镜像中提供了该系统镜像,用户可直接在控制台中更换此系统。并通过远程链接进入到系统中。

vsftpd是linux下的一款小巧轻快,安全易用的FTP服务器软件,是一款在各个Linux发行版中最受推崇的FTP服务器软件。

1.安装vsftpd,直接yum 安装就可以了

yum install -y vsftpd

出现下图表示安装成功。

2.相关配置文件:

cd /etc/vsftpd

/etc/vsftpd/vsftpd.conf                    //主配置文件,核心配置文件

/etc/vsftpd/ftpusers                        //黑名单,这个里面的用户不允许访问FTP服务器

/etc/vsftpd/user_list                       //白名单,允许访问FTP服务器的用户列表

3.启动服务

systemctl enable vsftpd.service                    //设置开机自启动

systemctl start vsftpd.service                    //启动ftp服务

netstat -antup | grep ftp               //查看ftp服务端口

登录ftp服务器。

匿名ftp的基本配置

使用匿名FTP,用户无需输入用户名密码即可登录FTP服务器,vsftpd安装后默认开启了匿名ftp的功能,用户无需额外配置即可使用匿名登录ftp服务器。

匿名ftp的配置在/etc/vsftpd/vsftpd.conf中设置。

anonymous_enable=YES //默认即为YES

这个时候任何用户都可以通过匿名方式登录ftp服务器,查看并下载匿名账户主目录下的各级目录和文件,但是不能上传文件或者创建目录。

为了演示效果,我们安装一个lftp软件。

yum -y install lftp             //安装lftp

利用lftp 公网ip连接到ftp服务器,可以看到只能查看和下载,不能进行上传操作

lftp 公网ip                       #连接到ftp服务器
cd pub/                         #切换到pub目录
put /etc/issue                   #上传文件
get test.1                       #下载文件

匿名ftp的其他设置

出于安全方面的考虑,vsftpd在默认情况下不允许用户通过匿名FTP上传文件,创建目录等更改操作,但是可以修改vsftpd.conf配置文件的选项,可以赋予匿名ftp更多的权限。

允许匿名ftp上传文件。 

修改/etc/vsftpd/vsftpd.conf

write_enable=YES

anon_upload_enable=YES

2、更改/var/ftp/pub目录的权限,为ftp用户添加写权限,并重新加载配置文件

chmod o+w /var/ftp/pub/                  #更改/var/ftp/pub目录的权限
systemctl restart vsftpd.service            #重启ftp服务

3、测试

配置本地用户登录

本地用户登录就是指使用Linux操作系统中的用户账号和密码登录ftp服务器,vsftp安装后默只支持匿名ftp登录,用户如果试图使用Linux操作系统中的账号登录服务器,将会被vsftpd拒绝

1.创建ftptest用户

useradd ftptest                 #创建ftptest用户
passwd ftptest                   #修改ftptest用户密码

2.修改/etc/vsftpd/vsftpd.conf

anonymous enable=NO

local_enable=YES

3.还是通过lftp连接到ftp服务器

另外简单介绍下vsftpd.conf的配置文件参数说明。

cat /etc/vsftpd/vsftpd.conf

用户登陆控制

参数 说明
anonymous_enable=YES 接受匿名用户
no_anon_password=YES 匿名用户login时不询问口令
anon_root=(none) 匿名用户主目录
local_enable=YES   接受本地用户
local_root=(none) 本地用户主目录

用户权限控制

参数 说明
write_enable=YES 可以上传(全局控制)
local_umask=022 本地用户上传文件的umask
file_open_mode=0666 上传文件的权限配合umask使用
anon_upload_enable=NO 匿名用户可以上传
anon_mkdir_write_enable=NO 匿名用户可以建目录
anon_other_write_enable=NO 匿名用户修改删除
chown_username=lightwiter 匿名上传文件所属用户名

相关连接

更多开源软件尽在云市场:https://market.aliyun.com/software

时间: 2024-09-14 16:20:31

云服务器ECS下的FTP服务的安装配置与使用的相关文章

云服务器 ECS 建站教程:Discuz安装教程

Discuz安装教程 Discuz! 是全球成熟度最高.覆盖率最大的论坛软件系统之一.自 2001 年 6 月面世以来,Discuz! 已拥有 15 年以上的应用历史和 200 多万网站用户案例.目前,Discuz! 已经发展成为一个以社区为基础的专业建站平台,让论坛(BBS).社交网络(SNS).门户(Portal).群组(Group).开放平台(Open Platform)应用充分融合于一体,帮助网站实现一站式服务. 适用对象 适用于熟悉 ECS,熟悉 Linux 系统,刚开始使用阿里云进行

阿里云服务器ECS怎么样?阿里云服务器ECS选择方案建议

如果我们的网站追求速度.且正规的站点,老蒋个人建议还是选择国内的主机商,以前我们都会选择虚拟主机,如今我们都会选择云主机.VPS等,一来稳定性高,二来具有独立IP等特点,利于网站的扩展.在目前国内的云主机服务商中,竞争还是很激烈的,小的IDC商家可能以后会区域终结,取而代之的是门户网站的云主机项目,比如阿里云.腾讯云.景安快云.百度云等等. 在这篇文章中,老蒋来分享对于新用户来说可能比较有用的,关于如何选择阿里云服务器ECS产品,因为在众多的配置方案和数据中心机房中,无从下手,所以这一篇还是比较

云服务器 ECS 建站教程:手动建站(Windows环境)

手动建站(Windows环境) 本节介绍如何使用阿里云镜像,一键部署 Web 环境,包括安装 IIS 组件(不包括 FTP 组件).PHP 环境.重定向 Rewrite.MySQL.phpwind.该示例不需要更换系统盘. 部署之前,请确保您的实例可以连接公网. 在浏览器中打开阿里云的云市场. 搜索 阿里云windows一键安装web环境,然后购买该软件. 登录阿里云管理控制台.打开 产品与服务 > 云市场. 单击 已购买的服务.在 阿里云Windows一键安装Web环境 的右侧,单击 管理.

阿里云服务器ECS(Ubuntu)搭建nginx服务器 详细步骤教程

假设阿里云服务器的ip是192.168.1.10(读者需要换成自己的ip地址),并且没有选择任何安装包.现在ECS是完全空的,除了必须的Linux系统外,其他什么都没有.还有一点,本文选择的是Ubuntu Linux 14.04 64位版本.Linux比较节省内存,因为并没有UI部分,纯控制台操作. 本文只安装nginx服务器,后面的文章会配置其他环节,如PHP.Java.MySQL等. 在安装之前需要完成如下两项工作. 找一个工具上传文件(如nginx安装包) 连接到服务器的Console上,

云服务器 ECS 建站教程:搭建Joomla基础管理平台

搭建Joomla基础管理平台 Joomla是一套知名的内容管理系统.Joomla是使用PHP语言加上Mysql数据开发的软件系统,Joomla的最新版本是3.x,这一版本实现了许多技术上的优化调整,是目前的稳定版本. 本文主要说明如何在阿里云ECS上搭建Joomla基础管理平台.使用的操作系统为Linux CentOS 6.5 64位. 适用对象 适用于熟悉 ECS,熟悉 Linux 系统, ECS 实例搭建刚开始使用阿里云进行建站的用户. 基本流程 使用云服务器 ECS 搭建 Joomla 平

云服务器 ECS 建站教程:搭建Magento电子商务网站(CentOS7)

搭建Magento电子商务网站(CentOS7) Magento是一款开源电商网站框架,其丰富的模块化架构体系及拓展功能可为大中型站点提供解决方案.它使用PHP开发,支持版本范围从PHP 5.6到PHP 7.1,并使用MySQL存储其数据.本文主要说明如何在阿里云ECS上搭建Magento电子商务网站.使用的操作系统为Linux CentOS 7. 2 64位. 适用对象 适用于熟悉ECS,熟悉Linux系统,刚开始使用阿里云进行建站的用户. 基本流程 使用云服务器 ECS 搭建Magento网

云服务器ECS,你真的懂吗?

云服务器ECS是阿里云最基础的弹性计算服务,总计规划了十余种规格族,几十种规格.用户在面对阿里云众多的产品种类,颇有种挑花了眼不知如何入手的感觉,本文就对阿里云最基础的云服务器ECS进行一下详细的介绍. 立即购买>>  了解详情>> 服务器ECS(Elastic Compute Service:弹性计算服务,对应亚马逊AWS的产品叫EC2,Elastic Compute Cloud)本质上是向用户提供的虚拟机资源,背后核心技术采用KVM.虽然,不少企业客户依然在用桌面虚拟化方面依然

云服务器ECS安全组实践(一)

应用上云除了对资源生命周期管理和应用交付是一个转变,更重要是思维方式的转变.本篇文章就简单介绍下上云的一个重要概念安全组(Security Group).本文是安全组系列的第一篇,主要介绍安全组的基本概念.约束和如何配置入网规则. 安全组的基本概念和约束 安全组在云端提供类似虚拟防火墙功能,用于设置单个或多个 ECS 实例的网络访问控制,它是重要的安全隔离手段.在创建 ECS 实例时,必须选择一个安全组.您还可以添加安全组规则,对该安全组下的所有 ECS 实例的出方向和入方向进行网络控制. 安全

云服务器 ECS 安全:如何提高ECS实例的安全性

如何提高ECS实例的安全性 云服务器 ECS 实例是一个虚拟的计算环境,包含了 CPU.内存.操作系统.磁盘.带宽等最基础的服务器组件,是 ECS 提供给每个用户的操作实体. 我们基本可以理解为一个实例就等同于一台虚拟机,那么我们在本地维护的虚拟机一般会做虚拟机实例级别的安全防护,以防止虚拟机被攻击和入侵等.同样的,云上的ECS实例也需要做安全性防护. ECS实例放置在云上,除了置身于阿里云自身的安全平台外,用户也需要根据实际的需求进一步定制化安全,所以说ECS的安全是阿里云和用户共同构建的.如