设为首页 加入收藏

TOP

转发器---转发网络通信
2017-09-30 13:37:20 】 浏览:7039
Tags:转发器 --- 转发 网络通信

 

功能:

支持本机和远程ip tcp数据转发。

支持tcp短连接(http等)和长连接(基于tcp大容量(GiB以上)文件传输)。

 

工作流程简述:

转发器建立监听端口p1,接收到新连接请求后,建立新连接s1,再建立与目标地址端口p2新连接s2,然后s1、s2组合为一条新转发线路。最后开始转发数据。

 

基于go语言开发,使用go默认net库。Go 语言层面采用阻塞+多协程模式,进行网络通信。

 

网络模型:

因为go的默认net库,底层基于非阻塞+多路复用模型(windows iocp、linux epoll),

所以转发器实质模型为非阻塞+多路复用模型。保证了转发器的高性能。

 

性能:

与之前的python版本相比,性能提高200-300倍。因为python版本,网络模型采用阻塞+多线程轮询模式,并非python的高性能网络模型。这样的性能差异与编程语言的执行效率并无太大关联。如果python使用异步多路复用模型,两者的性能差应该在10-20倍之间。

 

基于http代理端口转发性能测试,python版本典型cpu占用为20%-30%,go版本典型cpu占用为0.05%-1%。

 

性能测试硬件平台:

 

Cpu  i3  2核心,4线程

内存 12GiB

硬盘 三星固态硬盘 120GiB

 

 

开源协议:

项目基于GPLv3协议开源。

 

项目代码:

项目网址:https://github.com/ypcd/Forwarder

 

使用说明:

 

使用者,需要设定两个address。

一个是转发器的监听address,一个是目标的address。

这些设定都需要在源代码中设定。

源代码forwarder.go -> main() -> service(第一个设定监听address) -> service(第二个设定目标address)

 

两个service 同名,行数不同。

 

设定好后,请在命令行中使用”go install timerm”,安装必要的包。

然后使用”go build forwarder.go” 获得forwarder可执行程序。

或者采用”go run forwarder.go” 直接运行。

 

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇golang:1.并发编程之互斥锁、读.. 下一篇Go1.8发布了

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目