天翼云主机部署配置ftp服务详解

2023-11-11 06:10

本文主要是介绍天翼云主机部署配置ftp服务详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家知道在服务器上上传下载文件有很多种方案比如最著名的ftp协议,或者安装lrzsz,这款工具比ftp服务安装配置要简单很多,今天我主要介绍ftp服务在centos7下的安装配置,首先来回顾一下ftp服务的两种工作模式:

一、ftp工作模式

ftp协议是tcp协议,有两个端口可以控制:

tcp 20用于数据传输

tcp 21用于控制或建立tcp连接

模式一(PORT模式又叫主动模式)

FTP服务器“主动”去连接客户端的数据端口,具体就是:客户端从一个端口N(N>1024)连接到FTP服务器的命令端口tcp 21,紧接着客户端开始监听端口N+1,并发送FTP命令“port N+1”到FTP服务器。然后服务器从数据端口(tcp 20)“主动”连接到客户端指定的数据端口(N+1),客户端就可和ftp服务器建立数据传输通道了。这里面的关键是主动模式的主动指的是服务器主动连接客户端建立数据传输通道。

主动模式服务器端需要开放tcp20,21两个端口

C代表客户端,S代表服务器

  • S打开端口20和21
  • C用一个随机端口连接到S的端口21,该端口可以在1024到65536之间,它将端口+ x同时发送到服务器以指定C(X)-> S(21)
  • 当S收到命令时,它将发送回ACK,S(21)-> C(X)
  • S将在其端口20和客户端的X + 1之间建立连接,S(20)-> C(X + 1)
  • C回应ACK,C(X + 1)-> S(20)

模式二(PASV模式又叫被动模式)

FTP服务器“被动”等待客户端来连接自己的数据端口,具体是:当开启一个FTP连接时,客户端打开两个任意的非特权本地端口(N >1024和N+1)。第一个端口连接服务器的21端口,客户端向服务器提交PASV命令,服务器收到会开启一个任意的非特权端口(P > 1024),并发送PORT P命令给客户端。然后客户端发起从本地端口N+1到服务器的端口P的连接用来传送数据。

被动模式下服务器需要开发21端口及用于让客户端建立数据通道的非特权端口就是大于1024的其它tcp端口,可以人工指定端口范围。

FTP工具或者浏览器默认使用的都是PASV模式连接FTP服务器

C代表客户端,S代表服务器

  • S打开端口21和大于1024的TCP端口
  • C使用一个随机端口连接到S的端口21,此随机端口的范围从1024到65535,它将发送命令PASV,C(X)-> S(21)
  • S接收命令并响应ACK,并指定新端口y,S(21)-> C(x)
  • C使用端口x + 1启动与S的y端口的连接。C(x + 1)-> S(y)
  • S返回一个ACK,S(y)-> C(x + 1)

二、安装ftp服务器

yum install vsftpd -y

在操作系统中安装ftp服务。

# systemctl start vsftpd
# systemctl enable vsftpd

三、配置ftp服务

首先备份默认配置文件

cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.orig

修改配置文件

vi /etc/vsftpd/vsftpd.conf

anonymous_enable=NO             # 禁用匿名用户登陆
local_enable=YES		# permit local logins
write_enable=YES		# 启用更改文件系统的ftp命令
local_umask=022		        # 为本地用户创建文件的umask值
dirmessage_enable=YES	        # enable showing of messages when users first enter a new directory
xferlog_enable=YES		# 启用上传、下载的日志功能,默认存储位置/var/log/xferlog
xferlog_std_format=YES          # keep standard log file format
listen=NO   			# prevent vsftpd from running in standalone mode
listen_ipv6=YES		        # vsftpd will listen on an IPv6 socket instead of an IPv4 one
pam_service_name=vsftpd         # name of the PAM service vsftpd will use
userlist_enable=YES  	        # 使用vsftpd加载一个用户列表,该列表中的用户可以登陆
userlist_deny=NO                # 默认在user_list列表中的用户不允许登陆,这条指允许列表中的用户登陆
tcp_wrappers=YES  		# turn on tcp wrappers
chroot_local_user=YES           # 限定登陆用户在其主目录下,不允许跳出到其它目录
allow_writeable_chroot=YES      # 与上面限定用户主目录配合开启
#主动模式配置
connect_from_port_20=YES # use port 20 (ftp-data) on the server machine for PORT style connections#被动模式配置
connect_from_port_20=NO
pasv_enable=yes
pasv_max_port=6010
pasv_min_port=6000

如果userlist_enable = YES,则userlist_file=/etc/vsftpd.userlist拒绝其中列出的用户的userlist_deny选项设置为YES的登录访问。userlist_deny = NO会更改设置,这意味着仅允许在userlist_file = / etc / vsftpd.userlist中明确列出的用户登录。

四、配置网络防火墙与selinux

# firewall-cmd --zone=public --permanent --add-port=21/tcp
# firewall-cmd --zone=public --permanent --add-service=ftp
# firewall-cmd --reload
设置SELinux允许FTP读取/写入用户的主目录
#semanage boolean -m ftpd_full_access --on
或者直接修改/etc/selinux/config文件直接禁用selinux,但是这样不安全,不建议使用。

五、配置ftp用户及用户目录权限

1、操作系统添加ftp登陆用户

useradd ftpuser -d /home/ftpuser -s /bin/false

chown ftpuser:ftpuser /home/ftpuser -R

passwd ftpuser

echo "ftpuser" | tee -a /etc/vsftpd/user_list

2、配置ftp用户目录权限

mkdir -p /home/ftpuser/ftp/upload

chmod 750 /home/ftpuser/ftp/upload

chown ftpuser /home/ftpuser/ftp/upload

chgrp ftpuser /home/ftpuser/ftp/upload

六、windows下安装图形化ftp客户端

下载安装图形化ftp工具filezilla,该款工具是免费软件。

下载链接如下

https://dl1.cdn.filezilla-project.org/client/FileZilla_3.45.1_win64.zip?h=O-8RxU9Mb0rxL-25bMES6A&x=1571107684

 

七、测试ftp服务

1、本地测试

ftp localhost

2、远程通过图形终端测试

这篇关于天翼云主机部署配置ftp服务详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/388078

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Linux内核之内核裁剪详解

《Linux内核之内核裁剪详解》Linux内核裁剪是通过移除不必要的功能和模块,调整配置参数来优化内核,以满足特定需求,裁剪的方法包括使用配置选项、模块化设计和优化配置参数,图形裁剪工具如makeme... 目录简介一、 裁剪的原因二、裁剪的方法三、图形裁剪工具四、操作说明五、make menuconfig

详解Java中的敏感信息处理

《详解Java中的敏感信息处理》平时开发中常常会遇到像用户的手机号、姓名、身份证等敏感信息需要处理,这篇文章主要为大家整理了一些常用的方法,希望对大家有所帮助... 目录前后端传输AES 对称加密RSA 非对称加密混合加密数据库加密MD5 + Salt/SHA + SaltAES 加密平时开发中遇到像用户的

Springboot使用RabbitMQ实现关闭超时订单(示例详解)

《Springboot使用RabbitMQ实现关闭超时订单(示例详解)》介绍了如何在SpringBoot项目中使用RabbitMQ实现订单的延时处理和超时关闭,通过配置RabbitMQ的交换机、队列和... 目录1.maven中引入rabbitmq的依赖:2.application.yml中进行rabbit

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.