当前位置: 首页 > news >正文

Nginx如何实现 TCP和UDP代理?

文章目录
  • 前言
    • Nginx之TCP和UDP代理
      • 工作原理
      • 示意图
    • 配置文件和命令参数注释
      • 基本命令
    • 配置实例说明
      • TCP代理实例
      • UDP代理实例
  • 总结

前言

Nginx是一个高性能的HTTP和反向代理服务器,同时也支持TCP/UDP代理。在1.9.13版本后,Nginx已经支持端口转发,包括TCP和UDP协议。Nginx的TCP/UDP代理功能允许它作为一个中间人,接收来自客户端的TCP或UDP请求,并将这些请求转发到指定的后端服务器,然后将后端服务器的响应返回给客户端。

Nginx之TCP和UDP代理

工作原理
  1. 配置:首先需要在Nginx的配置文件中设置TCP/UDP代理的相关参数,例如监听的端口、后端服务器的地址和端口等。
  2. 监听:Nginx根据配置文件中的设置,在指定端口上监听来自客户端的连接请求。
  3. 连接:当接收到客户端的连接请求后,Nginx会立即尝试与后端服务器建立连接。
  4. 数据转发:建立连接后,Nginx将客户端发送的数据转发给后端服务器,并将后端服务器的响应数据转发回客户端。
  5. 保持连接:Nginx支持长连接和短连接,根据实际需求保持或关闭与客户端及后端服务器的连接。
  6. 安全和优化:Nginx还提供了SSL/TLS加密、负载均衡、故障转移等高级功能,以增强TCP/UDP代理服务的安全性和稳定性。
示意图
+--------+      +--------+      +--------+
|  Client | ---> |   Nginx  | ---> | Backend|
+--------+      +--------+      +--------+

配置文件和命令参数注释

Nginx的配置文件一般位于Nginx安装目录下的conf目录下,主要配置文件是nginx.conf。以下是一些基本的配置指令和它们的注释:

# 工作进程的数量
worker_processes  auto;# 错误日志文件的位置和日志级别
error_log /var/log/nginx/error.log info;# 事件模块配置
events {# 每个工作进程允许的最大连接数worker_connections  1024;
}# HTTP模块配置
http {# 包含MIME类型的配置文件include       mime.types;# 默认的MIME类型default_type  application/octet-stream;# 日志格式log_format  main  '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';# 访问日志的位置access_log  logs/access.log  main;# 开启高效传输文件的模式sendfile     on;# TCP_NODELAY选项设置tcp_nopush   on;# TCP_NODELAY选项设置tcp_nodelay  on;# 长连接超时时间keepalive_timeout  65;# 其他配置...
}# TCP/UDP 模块配置
stream {# TCP代理配置upstream backend {server 127.0.0.1:12345  max_fails=3 fail_timeout=30s;}server {listen 12345;proxy_connect_timeout 1s;proxy_timeout 3s;proxy_pass backend;}# UDP代理配置upstream udp_backend {server 192.168.31.51:514;}server {listen 1514 udp;proxy_pass udp_backend;}
}
基本命令
  • nginx -t:检查配置文件是否有语法错误。
  • nginx -s reload:热加载,重新加载配置文件。
  • nginx -s stop:快速关闭。
  • nginx -s quit:等待工作进程处理完成后关闭。

配置实例说明

TCP代理实例

以下是对Nginx TCP代理配置的详细注释:

# 定义一个名为 'stream' 的上下文,用于配置TCP/UDP代理
stream {# 定义一个上游服务器组 'backend',用于存放后端服务器的信息upstream backend {# 指定上游服务器组中的一个服务器,这里是本机的12345端口server 127.0.0.1:12345; # 设置最大失败尝试次数为3次max_fails=3; # 设置失败后超时时间为30秒fail_timeout=30s;}# 定义一个服务器块,用于监听和代理TCP流量server {# 监听本地的12345端口,用于接收客户端的TCP连接listen 12345;# 设置与后端服务器建立连接的超时时间为1秒proxy_connect_timeout 1s;# 设置与后端服务器通信的超时时间为3秒proxy_timeout 3s;# 将流量代理到定义的 'backend' 上游服务器组proxy_pass backend;}
}

这段配置的主要作用是让Nginx监听本地的12345端口,并将所有接收到的TCP连接转发到本地的另一个服务上,该服务运行在12345端口上。同时,配置中还包含了对后端服务的健康检查和故障转移机制,如果后端服务连续3次无法连接,则认为该服务失败,并在30秒超时后尝试重新连接。这样可以提高代理服务的可用性和稳定性。

UDP代理实例

以下是对Nginx UDP代理配置的详细注释:

# 定义一个名为 'stream' 的上下文,用于配置TCP/UDP代理
stream {# 定义一个上游服务器组 'udp_backend',用于存放后端UDP服务器的信息upstream udp_backend {# 指定上游服务器组中的一个服务器,这里是192.168.31.51的514端口server 192.168.31.51:514;}# 定义一个服务器块,用于监听和代理UDP流量server {# 监听本地的1514端口,接收来自客户端的UDP数据包listen 1514 udp;# 将接收到的UDP流量代理到定义的 'udp_backend' 上游服务器组proxy_pass udp_backend;}
}

说明:

  1. stream:这是一个上下文块,专门用于配置TCP和UDP的流量代理。与HTTP上下文不同,stream上下文处理的是原始的网络流量。

  2. upstream udp_backend:定义一个名为udp_backend的上游服务器组,里面包含了后端UDP服务器的信息。在这个例子中,只有一个服务器。

  3. server 192.168.31.51:514:指定上游服务器的IP地址和端口号。在这里,Nginx将把接收到的UDP数据包转发到192.168.31.51的514端口。

  4. server:定义一个服务器块,用于处理UDP流量的监听和代理。

  5. listen 1514 udp:Nginx将监听本地的1514端口,接收来自客户端的UDP数据包。udp关键字指示Nginx以UDP模式工作。

  6. proxy_pass udp_backend:将接收到的UDP流量代理到之前定义的udp_backend上游服务器组。Nginx会将客户端发送到1514端口的UDP数据包转发到192.168.31.51的514端口。

通过这种配置,Nginx可以作为一个UDP代理服务器,将流量转发到指定的后端服务器,适用于需要UDP协议的应用场景,例如Syslog等。

总结

通过这些配置,Nginx可以作为一个强大的TCP/UDP代理服务器,适用于多种应用场景,如数据库、邮件服务器、游戏服务器等。

相关文章:

Nginx如何实现 TCP和UDP代理?

文章目录 前言 Nginx之TCP和UDP代理 工作原理示意图 配置文件和命令参数注释 基本命令 配置实例说明 TCP代理实例UDP代理实例 总结 前言 Nginx是一个高性能的HTTP和反向代理服务器,同时也支持TCP/UDP代理。在1.9.13版本后,Nginx已经支持端口转发&…...

蓝桥杯思维训练营(三)

文章目录 题目详解680.验证回文串 II30.魔塔游戏徒步旅行中的补给问题观光景点组合得分问题 题目详解 680.验证回文串 II 680.验证回文串 II 思路分析:这个题目的关键就是,按照正常来判断对应位置是否相等,如果不相等,那么就判…...

开箱即用的.NET MAUI组件库 V-Control 发布了!

之前写过挺多的MAUI Sample,其中有很多代码可以打包成组件,当组件完善到一定程度,我会把控件封装起来放到控件库中。 今天,在这个仓库建立一年零八个月后,我觉得可以考虑将其作为开源库发布。 有很多网友在观望.NET …...

动手学图神经网络(9):利用图神经网络进行节点分类 WeightsBiases

利用图神经网络进行节点分类Weights&Biases 引言 在本篇博客中,将深入探讨如何使用图神经网络(GNNs)来完成节点分类任务。以 Cora 数据集为例,该数据集是一个引用网络,节点代表文档,推断每个文档的类别。同时,使用 Weights & Biases(W&B)来跟踪实验过程和…...

【文件上传、秒传、分片上传、断点续传、重传】

文章目录 获取文件对象文件上传&#xff08;秒传、分片上传、断点续传、重传&#xff09;优化 获取文件对象 input标签的onchange方法接收到的参数就是用户上传的所有文件 <html lang"en"><head><title>文件上传</title><style>#inp…...

使用Pygame制作“打砖块”游戏

1. 前言 打砖块&#xff08;Breakout / Arkanoid&#xff09; 是一款经典街机游戏&#xff0c;玩家控制一个可左右移动的挡板&#xff0c;接住并反弹球&#xff0c;击碎屏幕上方的砖块。随着砖块被击碎&#xff0c;不仅能获得分数&#xff0c;还可以体验到不断加速或复杂的反弹…...

【完整版】DeepSeek-R1大模型学习笔记(架构、训练、Infra)

文章目录 0 DeepSeek系列总览1 模型架构设计基本参数专家混合模型&#xff08;MoE&#xff09;[DeepSeek-V2提出, DeepSeek-V3改良]多头潜在注意力&#xff08;MLA&#xff09;[DeepSeek-V2提出]多token预测&#xff08;MTP&#xff09;[DeepSeek-V3提出] 2 DeepSeek-R1-Zero及…...

深入解析:如何利用 Python 爬虫获取商品 SKU 详细信息

在电商领域&#xff0c;SKU&#xff08;Stock Keeping Unit&#xff0c;库存单位&#xff09;详细信息是电商运营的核心数据之一。它不仅包含了商品的规格、价格、库存等关键信息&#xff0c;还直接影响到库存管理、价格策略和市场分析等多个方面。本文将详细介绍如何利用 Pyth…...

【3】高并发导出场景下,服务器性能瓶颈优化方案-文件压缩

使用EasyExcel导出并压缩文件是一种高效且常见的解决方案&#xff0c;尤其适用于需要处理大量数据的场景。 1. 导出多个Excel文件并压缩成ZIP文件的基本流程 &#xff08;1&#xff09;数据准备&#xff1a;从数据库或其他数据源获取需要导出的数据&#xff0c;并将其存储在Ja…...

FPGA|生成jic文件固化程序到flash

1、单击file-》convert programming files 2、flie type中选中jic文件&#xff0c;configuration decive里根据自己的硬件选择&#xff0c;单击flash loader选择右边的add device选项 3、选择自己的硬件&#xff0c;单击ok 4、选中sof选项&#xff0c;单机右侧的add file 5、选…...

【ArcGIS_Python】使用arcpy脚本将shape数据转换为三维白膜数据

说明&#xff1a; 该专栏之前的文章中python脚本使用的是ArcMap10.6自带的arcpy&#xff08;好几年前的文章&#xff09;&#xff0c;从本篇开始使用的是ArcGIS Pro 3.3.2版本自带的arcpy&#xff0c;需要注意不同版本对应的arcpy函数是存在差异的 数据准备&#xff1a;准备一…...

用Python获取股票数据并实现未来收盘价的预测

获取数据 先用下面这段代码获取上证指数的历史数据&#xff0c;得到的csv文件数据&#xff0c;为后面训练模型用的 import akshare as ak import pandas as pd# 获取上证指数历史数据 df ak.stock_zh_index_daily(symbol"sh000001")# 将数据保存到本地CSV文件 df.…...

Rust 所有权特性详解

Rust 所有权特性详解 Rust 的所有权系统是其内存安全的核心机制之一。通过所有权规则&#xff0c;Rust 在编译时避免了常见的内存错误&#xff08;如空指针、数据竞争等&#xff09;。本文将从堆内存与栈内存、所有权规则、变量作用域、String 类型、内存分配、所有权移动、Cl…...

Gateway路由匹配规则详解

在微服务架构中&#xff0c;Gateway作为请求的入口&#xff0c;扮演着至关重要的角色。它不仅负责路由转发&#xff0c;还具备安全、监控、限流等多种功能。其中&#xff0c;路由匹配规则是Gateway的核心功能之一&#xff0c;它决定了请求如何被正确地转发到目标服务。本文将详…...

项目实操:windows批处理拉取git库和处理目录、文件

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码指引&#xff1a;github源…...

前端开发知识梳理 - HTMLCSS

1. 盒模型 由内容区&#xff08;content&#xff09;、内边距&#xff08;padding&#xff09;、边框&#xff08;border&#xff09;和外边距&#xff08;margin&#xff09;组成。 &#xff08;1&#xff09;标准盒模型&#xff08;box-sizing默认值, content-box&#xff…...

nginx中的proxy_set_header参数详解

在使用 Nginx 作为反向代理服务器时&#xff0c;proxy_set_header 指令扮演着至关重要的角色。它允许我们自定义请求头信息&#xff0c;将客户端请求传递给上游服务器时&#xff0c;添加或修改特定的信息&#xff0c;从而实现更灵活的代理功能。本文将深入探讨 proxy_set_heade…...

MapReduce是什么?

MapReduce 是一种编程模型&#xff0c;最初由 Google 提出&#xff0c;旨在处理大规模数据集。它是分布式计算的一个重要概念&#xff0c;通常用于处理海量数据并进行并行计算。MapReduce的基本思想是将计算任务分解为两个阶段&#xff1a;Map 阶段和 Reduce 阶段。 Map 阶段&a…...

Text2Sql:开启自然语言与数据库交互新时代(3030)

一、Text2Sql 简介 在当今数字化时代&#xff0c;数据处理和分析的需求日益增长。对于众多非技术专业人员而言&#xff0c;数据库操作的复杂性常常成为他们获取所需信息的障碍。而 Text2Sql 技术的出现&#xff0c;为这一问题提供了有效的解决方案。 Text2Sql&#xff0c;即文…...

《图解设计模式》笔记(五)一致性

十一、Composite模式&#xff1a;容器与内容的一致性 像文件夹与文件一样&#xff0c;文件夹中可以放子文件夹与文件&#xff0c;再比如容器中可以放更小的容器和具体内容。 Composite模式&#xff1a;使容器与内容具有一致性&#xff0c;创造出递归结构。 Composite&#x…...

Xshell远程连接Kali(默认 | 私钥)Note版

前言:xshell远程连接&#xff0c;私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...

AtCoder 第409​场初级竞赛 A~E题解

A Conflict 【题目链接】 原题链接&#xff1a;A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串&#xff0c;只有在同时为 o 时输出 Yes 并结束程序&#xff0c;否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

2021-03-15 iview一些问题

1.iview 在使用tree组件时&#xff0c;发现没有set类的方法&#xff0c;只有get&#xff0c;那么要改变tree值&#xff0c;只能遍历treeData&#xff0c;递归修改treeData的checked&#xff0c;发现无法更改&#xff0c;原因在于check模式下&#xff0c;子元素的勾选状态跟父节…...

QT: `long long` 类型转换为 `QString` 2025.6.5

在 Qt 中&#xff0c;将 long long 类型转换为 QString 可以通过以下两种常用方法实现&#xff1a; 方法 1&#xff1a;使用 QString::number() 直接调用 QString 的静态方法 number()&#xff0c;将数值转换为字符串&#xff1a; long long value 1234567890123456789LL; …...

深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用

文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么&#xff1f;1.1.2 感知机的工作原理 1.2 感知机的简单应用&#xff1a;基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...

Golang——7、包与接口详解

包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...

WebRTC调研

WebRTC是什么&#xff0c;为什么&#xff0c;如何使用 WebRTC有什么优势 WebRTC Architecture Amazon KVS WebRTC 其它厂商WebRTC 海康门禁WebRTC 海康门禁其他界面整理 威视通WebRTC 局域网 Google浏览器 Microsoft Edge 公网 RTSP RTMP NVR ONVIF SIP SRT WebRTC协…...

【51单片机】4. 模块化编程与LCD1602Debug

1. 什么是模块化编程 传统编程会将所有函数放在main.c中&#xff0c;如果使用的模块多&#xff0c;一个文件内会有很多代码&#xff0c;不利于组织和管理 模块化编程则是将各个模块的代码放在不同的.c文件里&#xff0c;在.h文件里提供外部可调用函数声明&#xff0c;其他.c文…...

SQL注入篇-sqlmap的配置和使用

在之前的皮卡丘靶场第五期SQL注入的内容中我们谈到了sqlmap&#xff0c;但是由于很多朋友看不了解命令行格式&#xff0c;所以是纯手动获取数据库信息的 接下来我们就用sqlmap来进行皮卡丘靶场的sql注入学习&#xff0c;链接&#xff1a;https://wwhc.lanzoue.com/ifJY32ybh6vc…...