云服务器使用教程-基于CentOS搭建 FTP 文件服务

简介: 云服务器使用教程之:基于 CentOS 搭建 FTP 文件服务 以前尊托云数发表过用宝塔、WDCP等环境软件搭建服务器环境的教程,今天我们来学习单项的FTP文件服务搭建。 FTP 是一个很实用的文件传输协议,方便在客户端和服务器之间进行文件的传输。

云服务器使用教程之:基于 CentOS 搭建 FTP 文件服务

以前尊托云数发表过用宝塔、WDCP等环境软件搭建服务器环境的教程,今天我们来学习单项的FTP文件服务搭建。

FTP 是一个很实用的文件传输协议,方便在客户端和服务器之间进行文件的传输。是Internet中应用非常广泛的服务之一。它可根据实际需要设置各用户的使用权限,同时还具有跨平台的特性,即在UNIX、Linux和Windows等操作系统中都可实现FTP客户端和服务器,相互之间可跨平台进行文件的传输。因此,FTP服务是网络中经常采用的资源共享方式之一。很多新手站长只会用windows系统的服务器,使用phpstudy或者wampserver这类软件来搭建环境,虽然可以运行网站,但并不是最优方案,如果你想入行专业站长行列,linux系统的服务器及环境搭建和应用部署就不得不学,本教程带您使用 vsftpd 来搭建一个 FTP 服务,并且创建专有的 FTP 登录账户,保障服务器安全。下面我就来学习基于 CentOS 搭建 FTP 文件服务。

搭建 FTP 文件服务之前,你得有一个云服务器,没有的站长可以点击这里购买阿里云等大品牌云服务器2折秒杀特惠产品,可以让你即省钱又能真正低成本拥有自己的云服务器,购买云服务器的时候记得选Centos操作系统,因为我们的FTP搭建教程是基于Centos来的,购买之后即可开始我们的 FTP 文件服务搭建之旅了。

下面的教程我们按步骤来:
第一步,通过你服务器用户名(root)和密码进入centos系统,如下图:
1

第二步,安装并启动 FTP 服务:安装 VSFTPD,使用 yum 安装 vsftpd,安装命令如下:

yum install vsftpd -y

当运行命令出现如下界面时,就说明已经安装完毕了:
1
启动 VSFTPD:安装完成后,启动 FTP 服务,启动命令如下:

service vsftpd start

运行命令结果如下图:
1

FTP 协议默认使用 21 端口作为服务端口,启动后,可以看到系统已经 监听了 21 端口

netstat -nltp | grep 21

此时,访问 ftp://你的服务器IP地址, 可浏览机器上的 /var/ftp 目录了。

第三步,配置 FTP 权限:
目前 FTP 服务登陆允许匿名登陆,也无法区分用户访问,我们需要配置 FTP 访问权限。
了解 VSFTP 配置
vsftpd 的配置目录为 /etc/vsftpd,包含下列的配置文件:
vsftpd.conf 为主要配置文件
ftpusers 配置禁止访问 FTP 服务器的用户列表
user_list 配置用户访问控制
阅读上述配置可以让你了解更多信息。我们了解这些信息之后,就可以开始下一步修改配置来设置权限。
阻止匿名访问和切换根目录,匿名访问和切换根目录都会给服务器带来安全风险,匿名访问让所有人都可以上传文件到服务器上而无需鉴权,而允许切换根目录则可能产生越权访问问题,我们把这两个功能关闭。
关闭方法如下,编辑 /etc/vsftpd/vsftpd.conf, 找到下面两处配置并修改:(小技巧:在代码编辑器中,用 Ctrl + F 进行搜索,Mac 用户用 Cmd + F 进行搜索)

# 禁用匿名用户
anonymous_enable=NO
# 禁止切换根目录
chroot_local_user=YES

1
2

编辑完成后,按 Ctrl + S 保存配置,重新启动 FTP 服务,重启命令如下:

service vsftpd restart

第四步,创建FTP用户,创建一个用户 ftpuser,命令如下:

useradd ftpuser

为用户 ftpuser 设置密码,命令如下:

echo "Password" | passwd ftpuser --stdin

命令执行结果如下界面:
1

说明一点,这里的FTP用户名和密码是你自己自由设置的,我这里便于理解,所以设置了“ftpuser”和 "Password"。

第五步,限制该用户仅能通过 FTP 访问:

限制用户 ftpuser 只能通过 FTP 访问服务器,而不能直接登录服务器,因为那样会有安全隐患,限制命令如下:

usermod -s /sbin/nologin ftpuser

第六步,为用户分配主目录:

为用户 ftpuser 创建主目录并约定:/data/ftp 为主目录, 该目录不可上传文件,/data/ftp/pub 文件只能上传到该目录下。

创建主目录执行如下命:

mkdir -p /data/ftp/pub

方便用户登录后可以看到欢迎信息,并且确定用户确实登录到了主目录上,我们需要给用户创建一个欢迎文件。创建登录欢迎文件,执行如下命令:

echo "Welcome to use FTP service." > /data/ftp/welcome.txt

设置访问权限,让用户对他的主目录有可读写权限,执行如下命令:

chmod a-w /data/ftp && chmod 777 -R /data/ftp/pub

把该目录设置为用户的主目录,执行如下命令:

usermod -d /data/ftp ftpuser

以上几个命令的执行结果如下图:

1

第七步,准备域名和证书,没有的可以通过尊托云数2折特惠秒杀网购买

如果您不需要通过域名访问 FTP 服务器则可以直接用IP地址访问,域名购买完成后, 需要将域名解析到你的服务器IP地址上。如果 ping 命令返回的信息中含有你设置的解析的 IP 地址,说明解析成功。ping命令如下:

ping www.yourdomain.com

第八步,访问 FTP 服务

FTP 服务已安装并配置完成,下面我们来使用该 FTP 服务,根据您个人的工作环境,选择一种方式来访问已经搭建的 FTP 服务。

a、Windows 用户可以复制下面的链接到资源管理器的地址栏访问:

ftp://ftpuser:Password@<您的服务器IP地址>

b、通过 FTP 客户端工具访问

FTP 客户端工具众多,下面推荐两个常用的:

WinSCP - Windows 下的 FTP 和 SFTP 连接客户端

FileZilla - 跨平台的 FTP 客户端,支持 Windows 和 Mac

下载和安装 FTP 客户端后,使用下面的凭据进行连接即可:

你的服务器IP地址、FTP用户名、FTP用户密码

1

如果能够正常连接,那么大功告成,您可以开始使用属于您自己的 FTP 服务器了!

接下来,请上传任意一张图片到您的 FTP 服务器上的pub目录下,然后,就可以在 /data/ftp/pub 中看到了。

注意: 请不要直接上传文件到根目录下,您应该选择上传到 pub 目录下

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
Linux 网络安全 Python
linux centos上安装python3.11.x详细完整教程
这篇文章提供了在CentOS系统上安装Python 3.11.x版本的详细步骤,包括下载、解压、安装依赖、编译配置、解决常见错误以及版本验证。
1166 1
linux centos上安装python3.11.x详细完整教程
|
3月前
|
Linux 数据安全/隐私保护 Perl
CentOS7中升级OpenSSL详细教程
这篇文章提供了在CentOS 7系统中升级OpenSSL到3.2版本的详细步骤,包括备份现有配置、安装依赖、下载安装新版本以及验证安装结果。
754 1
|
2月前
|
Linux Docker 容器
Centos安装docker(linux安装docker)——超详细小白可操作手把手教程,包好用!!!
本篇博客重在讲解Centos安装docker,经博主多次在不同服务器上测试,极其的稳定,尤其是阿里的服务器,一路复制命令畅通无阻。
1041 4
Centos安装docker(linux安装docker)——超详细小白可操作手把手教程,包好用!!!
|
2月前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
82 1
|
3月前
|
分布式计算 Hadoop Java
Hadoop集群搭建,基于3.3.4hadoop和centos8【图文教程-从零开始搭建Hadoop集群】,常见问题解决
本文是一份详细的Hadoop集群搭建指南,基于Hadoop 3.3.4版本和CentOS 8操作系统。文章内容包括虚拟机创建、网络配置、Java与Hadoop环境搭建、克隆虚拟机、SSH免密登录设置、格式化NameNode、启动Hadoop集群以及通过UI界面查看Hadoop运行状态。同时,还提供了常见问题的解决方案。
Hadoop集群搭建,基于3.3.4hadoop和centos8【图文教程-从零开始搭建Hadoop集群】,常见问题解决
|
3月前
|
Unix Linux 开发工具
centos的官网下载和vm16虚拟机安装centos8【保姆级教程图解】
本文详细介绍了如何在官网下载CentOS 8以及在VMware Workstation Pro 16虚拟机上安装CentOS 8的步骤,包括可能出现的问题和解决方案,如vcpu-0错误的处理方法。
centos的官网下载和vm16虚拟机安装centos8【保姆级教程图解】
|
2月前
|
弹性计算 关系型数据库 MySQL
CentOS 7.x操作系统的ECS云服务器上搭建WordPress网站
CentOS 7.x操作系统的ECS云服务器上搭建WordPress网站
|
2月前
|
Linux
VirtualBox的Centos上安装GNOME桌面完整教程
在VirtualBox上的CentOS系统安装GNOME桌面环境的完整教程,通过执行一系列命令来安装EPEL软件源、GNOME桌面环境,并配置系统默认运行级别为图形界面。
60 0
|
4月前
|
Linux 开发工具 数据安全/隐私保护
CentOS7安装流程步骤详细教程
【8月更文挑战第22天】
731 2
CentOS7安装流程步骤详细教程
|
4月前
|
Linux PHP
Linux CentOS 宝塔 Suhosin禁用php5.6版本eval函数详细图文教程
【8月更文挑战第27天】本文介绍两种禁用PHP执行的方法:使用`PHP_diseval_extension`禁用和通过`suhosin`禁用。由于`suhosin`不支持PHP8,仅适用于PHP7及以下版本,若服务器安装了PHP5.6,则需对应安装`suhosin-0.9.38`版本。文章提供了详细的安装步骤,并强调了宝塔环境下与普通环境下的PHP路径差异。安装完成后,在`php.ini`中添加`suhosin.so`扩展并设置`executor.disable_eval = on`以禁用执行功能。最后通过测试代码验证是否成功禁用,并重启`php-fpm`服务生效。
51 2