关于“内网可以访问21端口,通过防火墙映射后无法访问”的问题解决

embedded/2024/11/28 1:35:17/

如果内网可以访问21端口,但通过防火墙映射后无法访问,这通常是因为防火墙或路由器的配置问题。以下是一些可能的解决方案和检查步骤:

1. 检查防火墙映射配置

确保你的防火墙或路由器已经正确配置了端口映射。通常,你需要将外部端口映射到内部服务器的21端口。例如,如果你的内部服务器IP地址是 192.168.1.100,并且你希望外部通过端口2121访问内部的21端口,你需要在防火墙或路由器上进行以下配置:

  • 外部端口:2121
  • 内部IP地址:192.168.1.100
  • 内部端口:21

2. 检查被动模式端口映射

如果使用被动模式(PASV),还需要将被动模式使用的端口范围也进行映射。假设你已经配置了被动模式端口范围为10000到10100,你需要在防火墙或路由器上进行以下配置:

  • 外部端口范围:10000-10100
  • 内部IP地址:192.168.1.100
  • 内部端口范围:10000-10100

3. 检查路由器的NAT配置

确保路由器的NAT(网络地址转换)配置正确。有些路由器可能需要额外的配置来确保数据连接能够正确通过。

4. 检查服务器的IP地址配置

确保vsftpd配置文件中正确配置了服务器的IP地址。编辑 /etc/vsftpd.conf 文件,添加或修改以下行:

pasv_enable=YES
pasv_min_port=10000
pasv_max_port=10100
pasv_address=公网ip
pasv_addr_resolve=YES

5. 检查防火墙规则

确保防火墙允许外部访问21端口和被动模式端口范围。如果你使用的是UFW(Uncomplicated Firewall),可以使用以下命令:

sudo ufw allow 21/tcp
sudo ufw allow 10000:10100/tcp

6. 检查网络连通性

使用 telnetnc 命令从外部网络测试端口连通性。例如:

telnet 221.11.32.26 21

如果连接成功,你应该会看到FTP服务器的欢迎消息。

7. 检查日志文件

查看vsftpd的日志文件,以获取更多关于连接问题的详细信息。日志文件通常位于 /var/log/vsftpd.log/var/log/xferlog

sudo tail -f /var/log/vsftpd.log

完整示例

以下是完整的步骤示例:

  1. 配置防火墙映射
    • 登录到你的防火墙或路由器管理界面。
    • 配置端口映射:
      • 外部端口:2121
      • 内部IP地址:192.168.1.100
      • 内部端口:21
    • 配置被动模式端口映射:
      • 外部端口范围:10000-10100
      • 内部IP地址:192.168.1.100
      • 内部端口范围:10000-10100
  2. 编辑vsftpd配置文件
    sudo nano /etc/vsftpd.conf
    
    添加或修改以下行:
    pasv_enable=YES
    pasv_min_port=10000
    pasv_max_port=10100
    pasv_address=公网ip
    pasv_addr_resolve=YES
    
  3. 保存并退出编辑器
  4. 配置防火墙规则
    sudo ufw allow 21/tcp
    sudo ufw allow 10000:10100
    

http://www.ppmy.cn/embedded/141057.html

相关文章

使用minio cllient(mc)完成不同服务器的minio的数据迁移和mc基本操作

前言 最近需要将一个服务器上的minio桶的数据迁移到新服务器上,所以学习了一下,使用的是minio client。 MinIO Client (mc) 是一个用于与 MinIO 和其他兼容 Amazon S3 的云存储服务交互的命令行工具。MinIO 是一个高性能的对象存储服务器,mc 提供了一个丰富的命令集来管理对…

责任链模式在spring security过滤器链中的应用

责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,它允许多个对象按照顺序处理请求,并且每个对象可以选择自己是否处理该请求或将其传递给下一个对象。 在Spring Security中,责任链模式得到了广泛应…

如何用1分钟遍历一个100TB的文件?

如何用1分钟遍历一个100TB的文件? 标题:**极速挑战:1分钟内遍历100TB文件的秘籍**引言硬盘和文件系统基础硬盘类型文件系统原理RAID技术分布式文件系统HDFS架构实现1分钟内遍历100TB文件的策略技术细节和操作流程配置HDFS代码实现流程图案例分析结论标题:极速挑战:1分钟内…

Nodemailer使用教程:在Node.js中发送电子邮件

目录 1. 简介 2. 安装 3. 基本配置 3.1 创建传输器 3.2 配置说明 4. 发送邮件 4.1 基本发送示例 4.2 发送验证码示例 5. 常见问题解决 5.1 "Greeting never received" 错误 5.2 安全建议 SMTP与邮件加密协议详解 1. SMTP简介 1.1 基本特点 2. 加密协…

基于Matlab实现Gabo滤波器(源码)

Gabor滤波器是一种在图像处理和计算机视觉领域广泛应用的线性滤波器,它结合了空间局部性和频率选择性,能够较好地模拟人类视觉系统对图像特征的感知。在Matlab中实现Gabor滤波器,可以有效地提取图像的纹理、边缘和方向信息,对于图…

企业为什么选择服务器托管服务?

大多数的企业用户都会选择将自己的服务器进行托管服务,而不是放置在公司或者是办公地点,本文就来探讨一下企业为什么会选择服务器托管服务呢? 服务器与普通的计算机是不同的,需要保持每天24小时不间断工作,所以服务器需…

Linux firewalld 命令详解

简介 firewalld 是一个在 Linux 中的防火墙管理工具,提供动态接口管理网络流量,它使用区域来定义网络连接的信任级别,并支持 IPv4 和 IPv6。 常用示例 启动防火墙 sudo systemctl start firewalld停止防火墙 sudo systemctl stop firewa…

postman的简单使用

导语:开发过程中免不了要使用postman发起并查看一些请求情况,以下为常用的一些postman的简单使用。 一、postman快速导入一个网页请求 1.右键请求 -->复制 -->以cURL(bash)格式复制 2.打开postman -->点击import --> 选择Raw text -->…