TCP转发隧道

news2025/4/15 15:51:52

✅ 功能特性:
1. 高并发支持:采用 threading.Thread + socket,可承载多并发连接
2. 异常处理完善:确保线程内异常不会崩溃整个程序
3. 可持续运行:守护线程 + 主线程监控机制
4. 运行状态监控:
• 当前活跃连接数
• 累计已完成请求数
5. 实时日志记录:每次连接及关闭、异常都记录到控制台,可接入日志文件
6. 详细代码注释:便于后续维护或交接

📦 优化后的完整代码(Python 3.x)

import socket
import threading
import time
import logging

# ---------------- 配置参数 ----------------
LOCAL_HOST = '0.0.0.0'         # 中间服务器监听地址
LOCAL_PORT = 8000              # 中间服务器监听端口
REMOTE_HOST = '192.168.1.100'  # 目标服务器地址
REMOTE_PORT = 9000             # 目标服务器端口

# ---------------- 日志配置 ----------------
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s [%(levelname)s] %(message)s',
    handlers=[
        logging.FileHandler("tcp_proxy.log"),
        logging.StreamHandler()
    ]
)

# ---------------- 运行状态监控变量 ----------------
active_connections = 0              # 当前活跃连接数
total_completed_connections = 0     # 总共完成连接数
lock = threading.Lock()             # 用于线程安全的状态变量访问

def forward(src_socket, dst_socket):
    """
    数据转发线程:不断从 src_socket 读取数据,并写入 dst_socket
    """
    try:
        while True:
            data = src_socket.recv(4096)
            if not data:
                break
            dst_socket.sendall(data)
    except Exception as e:
        logging.warning(f"数据转发异常:{e}")
    finally:
        # 结束时关闭 socket
        src_socket.close()
        dst_socket.close()

def handle_client(client_socket, client_addr):
    """
    客户端连接处理线程:连接目标服务器,并启动双向转发
    """
    global active_connections, total_completed_connections
    logging.info(f"[+] 接收到来自 {client_addr} 的连接")

    # 更新活跃连接数
    with lock:
        active_connections += 1

    try:
        # 连接目标服务器
        remote_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        remote_socket.connect((REMOTE_HOST, REMOTE_PORT))
        logging.info(f"[→] 成功连接目标服务器 {REMOTE_HOST}:{REMOTE_PORT}")

        # 启动两个线程:客户端 -> 目标服务器,目标服务器 -> 客户端
        t1 = threading.Thread(target=forward, args=(client_socket, remote_socket), daemon=True)
        t2 = threading.Thread(target=forward, args=(remote_socket, client_socket), daemon=True)
        t1.start()
        t2.start()

        # 等待两个线程结束
        t1.join()
        t2.join()

        # 统计已完成请求
        with lock:
            total_completed_connections += 1
        logging.info(f"[✓] 连接 {client_addr} 完成转发并已关闭")

    except Exception as e:
        logging.error(f"[×] 处理连接 {client_addr} 出错:{e}")
    finally:
        # 保证连接数一致
        with lock:
            active_connections -= 1
        client_socket.close()

def monitor_status():
    """
    监控线程:每10秒打印一次运行状态
    """
    while True:
        with lock:
            logging.info(f"[监控] 当前活跃连接:{active_connections} | 累计完成连接:{total_completed_connections}")
        time.sleep(10)

def start_proxy():
    """
    主启动函数:监听端口,接收连接,分配处理线程
    """
    server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    server.bind((LOCAL_HOST, LOCAL_PORT))
    server.listen(100)  # 最大监听队列数
    logging.info(f"[启动] TCP 中转服务启动,监听 {LOCAL_HOST}:{LOCAL_PORT}")

    # 启动状态监控线程
    threading.Thread(target=monitor_status, daemon=True).start()

    while True:
        try:
            client_socket, client_addr = server.accept()
            handler_thread = threading.Thread(target=handle_client, args=(client_socket, client_addr), daemon=True)
            handler_thread.start()
        except Exception as e:
            logging.error(f"[×] 接收连接出错:{e}")

if __name__ == '__main__':
    start_proxy()

🧩 说明

部分 描述
forward() 双向数据转发函数,保持 TCP 长连接
handle_client() 为每个客户端建立目标连接并开启转发线程
monitor_status() 每10秒打印一次当前连接状态和统计信息
logging 日志记录模块,可写入文件并打印到控制台
lock 线程安全更新全局变量

📈 监控扩展建议(可选)

如果后续需要对接 Prometheus 或可视化平台,可以:
• 使用 prometheus_client 模块暴露指标(如 /metrics HTTP 接口)
• 将日志接入 ELK、Loki、OpenObserve 等日志系统

🧪 使用 Python 通过 TCP 中转器请求百度搜索“老师”(测试用)

🧩 场景说明

你已经实现了一个 TCP 中转代理程序(监听 localhost:8000),现在你需要一个 Python 客户端程序,通过这个代理向百度发送 HTTP 请求,搜索关键词“老师”,用来测试中转器的转发是否正常工作。

📌 流程示意图

Python 测试程序
   ↓(原始 TCP 请求)
中转器 (localhost:8000)
   ↓(TCP 转发)
百度服务器 (www.baidu.com:80)

✅ 测试代码(带详细注释)

import socket

# ------------------------- 配置中转器地址 -------------------------
PROXY_HOST = '127.0.0.1'   # 中间服务器地址(假设你的转发器就在本机)
PROXY_PORT = 8000          # 中间服务器监听的端口

# ------------------------- 构造 HTTP 请求 -------------------------
# 目标请求是百度搜索“老师”
keyword = "老师"
path = f"/s?wd={keyword}"  # 百度搜索路径,GET 请求参数放在 URL 中

# 注意:这里请求的是百度服务器,但是通过中转器转发出去
http_request = (
    f"GET {path} HTTP/1.1\r\n"
    f"Host: www.baidu.com\r\n"
    f"User-Agent: Python-TCP-Test\r\n"
    f"Connection: close\r\n"
    f"\r\n"
)

# ------------------------- 通过 TCP socket 请求 -------------------------
try:
    # 1. 建立与中间服务器的 TCP 连接
    client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client_socket.connect((PROXY_HOST, PROXY_PORT))
    print(f"✅ 成功连接中转服务器 {PROXY_HOST}:{PROXY_PORT}")

    # 2. 发送 HTTP 请求(给百度服务器的请求,但通过中转器发)
    client_socket.sendall(http_request.encode('utf-8'))
    print(f"📤 已发送百度搜索请求:{path}")

    # 3. 接收响应内容
    response_data = b""
    while True:
        chunk = client_socket.recv(4096)
        if not chunk:
            break
        response_data += chunk

    # 4. 打印前部分响应内容(HTML 页面)
    print("📥 收到响应内容:")
    print(response_data.decode('utf-8', errors='ignore')[:500])
    print("...(以下省略)")

except Exception as e:
    print(f"❌ 发生异常:{e}")

finally:
    # 5. 关闭连接
    client_socket.close()
    print("🔚 已关闭连接")

🔧 配置中转器(回顾)

你的 TCP 中转程序应设置如下目标地址(转发到百度):

REMOTE_HOST = "www.baidu.com"
REMOTE_PORT = 80

📝 注意事项
• 请确保你的中转器程序已经启动并监听正确的端口
• 中转器的机器能访问外网(百度)
• 百度响应的是 HTML 页面,你可以看到类似 … 的网页内容

🚀 下一步建议(可选扩展)
• 使用 BeautifulSoup 提取网页中搜索结果标题
• 用 threading 发送多个并发请求测试中转器性能
• 将响应写入文件用于调试排查

如需我写并发测试版本或 HTML 内容解析器,也可以继续提!😎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2334287.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React 学习 JSX

APP根组件被index.js渲染到public下的index.html下 JS中写 HTML 代码 渲染列表 条件渲染 复杂条件渲染 事件绑定 传递自定义参数 button标签中写箭头函数引用的格式 自定义参数和事件本身对象都想要的情况

大模型论文:Language Models are Few-Shot Learners(GPT3)

大模型论文:Language Models are Few-Shot Learners(GPT3) 文章地址:https://proceedings.neurips.cc/paper_files/paper/2020/file/1457c0d6bfcb4967418bfb8ac142f64a-Paper.pdf 一、摘要 我们证明了,扩大语言模型的规模在任务无关的 few…

一周学会Pandas2 Python数据处理与分析-Pandas2数据导出

锋哥原创的Pandas2 Python数据处理与分析 视频教程: 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 任何原始格式的数据载入DataFrame后,都可以使用类似 DataFrame.to_csv()的方法输出到相应格式的文件或者…

深入解析栈式虚拟机与反向波兰表示法

1.1 什么是虚拟机? 虚拟机(Virtual Machine, VM)是一种软件实现的计算机系统,提供与物理计算机相类似的环境,但在软件层面运行。虚拟机的存在简化了跨平台兼容性、资源管理以及安全隔离等问题。 1.2 栈式虚拟机的架构…

学习MySQL的第八天

海到无边天作岸 山登绝顶我为峰 一、数据库的创建、修改与删除 1.1 引言 在经过前面七天对于MySQL基本知识的学习之后,现在我们从基本的语句命令开始进入综合性的语句的编写来实现特定的需求,从这里开始需要我们有一个宏观的思想&…

AI识别与雾炮联动:工地尘雾治理新途径

利用视觉分析的AI识别用于设备联动雾炮方案 背景 在建筑工地场景中,人工操作、机械作业以及环境因素常常导致局部出现大量尘雾。传统监管方式存在诸多弊端,如效率低、资源分散、监控功能单一、人力效率低等,难以完美适配现代工程需求。例如…

GD32F303-IAP的过程和实验

使用的芯片为GD32F303VC 什么是IAP呢?有个博主写的很清楚;就是远程升级; 【单片机开发】单片机的烧录方式详解(ICP、IAP、ISP)_isp烧录-CSDN博客 我们需要写一个boot 和APP 通过 boot对APP的程序进行更新&#xf…

众趣科技助力商家“以真示人”,让消费场景更真实透明

在当今的消费环境中,消费者权益保护问题日益凸显。无论是网购商品与实物不符、预定酒店民宿与图文描述差异大,还是游览景区遭遇“照骗”,这些问题不仅让消费者在消费和决策过程中倍感困扰,也让商家面临信任危机。 消费者在享受便…

spark core编程之行动算子、累加器、广播变量

一、RDD 行动算子 reduce:聚集 RDD 所有元素,先聚合分区内数据,再聚合分区间数据。 collect:在驱动程序中以数组形式返回数据集所有元素。 foreach:分布式遍历 RDD 元素并调用指定函数。 count:返回 RDD…

提高课:数据结构之树状数组

1&#xff0c;楼兰图腾 #include<iostream> #include<cstring> #include<cstdio> #include<algorithm>using namespace std;typedef long long LL;const int N 200010;int n; int a[N]; int tr[N]; int Greater[N], lower[N];int lowbit(int x) {ret…

基于javaweb的SpringBoot新闻视频发布推荐评论系统(源码+部署文档)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…

机器学习之PCA主成分分析详解

文章目录 引言一、PCA的概念二、PCA的基本数学原理2.1 内积与投影2.2 基2.3 基变换2.4 关键问题及优化目标2.5 方差2.6 协方差2.7 协方差矩阵2.8 协方差矩阵对角化 三、PCA执行步骤总结四、PCA计算实例五、PCA参数解释六、代码实现七、PCA的优缺点八、总结 引言 在机器学习领域…

回溯——固定套路 | 面试算法12道

目录 输出二叉树所有路径 路径总和问题 组合总和问题 分割回文串 子集问题 排列问题 字母大小写全排列 单词搜索 复原IP地址 电话号码问题 括号生成问题 给我一种感觉是回溯需要画图思考是否需要剪枝。 元素个数n相当于树的宽度&#xff08;横向&#xff09;&#x…

Maven和MyBatis学习总结

目录 Maven 1.Maven的概念&#xff1a; 2.在具体的使用中意义&#xff1a; 3.与传统项目引入jar包做对比&#xff1a; 传统方式&#xff1a; 在maven项目当中&#xff1a; 4.在创建maven项目后&#xff0c;想要自定义一些maven配置 5.maven项目的结构 6.maven指令的生…

AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版

AndroidTV 当贝播放器 链接&#xff1a;https://pan.xunlei.com/s/VONXRf0g3cT0ECVt6GEsoODFA1?pwds4qv# AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版

Python生成exe

其中的 -w 参数是 PyInstaller 用于窗口模式&#xff08;Windowed mode&#xff09;&#xff0c;它会关闭命令行窗口的输出&#xff0c;这通常用于 图形界面程序&#xff08;GUI&#xff09;&#xff0c;比如使用 PyQt6, Tkinter, PySide6 等。 所以&#xff1a; 如果你在没有…

MySql 自我总结

目录 1. 数据库约束 1.1约束类型 2. 表的设计 2.1 一对一 2.2 一对多 2.3 多对多 3. 新增 4. 查询 4.1 聚合查询 4.2 GROUP BY 4.3 HAVING 4.4 联合查询 4.5 内连接 4.5.1 内连接的核心概念 4.5.2 内连接的语法 4.5.3 ON 与 WHERE 的区别 4.6 自连接 4.6.1 定…

uni-app app 安卓和ios防截屏

首先可参考文档 uni.setUserCaptureScreen 这里需要在项目中引入这个插件 uni-usercapturescreen - DCloud 插件市场 否则会报错,在需要防止截屏录屏的页面中,加入 uni.setUserCaptureScreen({enable: false,success() {console.log(全局截屏录屏功能已禁用);},fail(err)…

【Go】windows下的Go安装与配置,并运行第一个Go程序

【Go】windows下的Go安装与配置&#xff0c;并运行第一个Go程序 安装环境&#xff1a;windows10 64位 安装版本&#xff1a;go1.16 windows/amd64 一、安装配置步骤 1.到官方网址下载安装包 https://golang.google.cn/dl/ 默认情况下 .msi 文件会安装在 c:\Go 目录下。可自行配…

vue3腾讯云直播 前端拉流(前端页面展示直播)

1、引入文件&#xff0c;在index.html <link href"https://tcsdk.com/player/tcplayer/release/v5.3.2/tcplayer.min.css" rel"stylesheet" /><!--播放器脚本文件--><script src"https://tcsdk.com/player/tcplayer/release/v5.3.2/t…