Code Monkey home page Code Monkey logo

gap-proxy's Introduction

简介

gap-proxy 是一个加速网络的 SOCKS5 安全代理工具。

mTCP

mTCP 是专门为 gap-proxy 设计的快速、可靠、加密安全、基于 UDP 的传输控制协议,借鉴了 KCP、TCP、Quic 协议的优点。技术特性:

  • 支持连接迁移,在 IP 地址变化的情况下保持连接不断
  • 从协议头到应用数据都使用了 AES-256-CFB 加密
  • 类似 HMAC 机制,可防止数据被篡改
  • 选择确认、快速重传、快速超时选择重传
  • KeepAlive,及时释放意外终止的连接
  • 快速建立、释放连接

mTCP 没有拥塞控制,只有流量控制,因此在高丢包率网络环境中,比使用了拥塞控制的 TCP 更快。

支持平台

gap-proxy 仅支持 macOS, Linux, 其他类 Unix 理论上支持,但并未测试过。

安装

提示:为了简单,如下操作在个人电脑,服务器上可都一样。

下载

根据所使用的操作系统从 releases 下载相应已编译好的二进制文件压缩包。

安装

首先在用户家目录新建 .gap-proxy 目录,接着在此目录里创建 config.json 配置文件,最后配置相关参数。举例:

$ vim ~/.gap-proxy/config.json

{
	"local":  "127.0.0.1:1186", # 客户端监听地址 (SOCKS5)
	"server": "8.8.8.8:2286",   # 服务器端监听地址
	"key":    "gap-proxy"       # 密钥
}

基本使用

启动

一旦安装并配置好后,在个人电脑系统上执行:

$ gap-proxy local start

然后在服务器上执行:

$ gap-proxy server start

这样便分别启动了 gap-localgap-server 后台进程。

代理

gap-proxy 只是个简单的 SOCKS5 代理,如果日常上网需要智能代理,可自己在浏览器安装代理管理插件,插件的 SOCKS5 地址填写为配置文件的 local 字段的地址。

流量控制

gap-proxy 的默认接收窗口为 256 个包,每个包最多能装 1420 字节数据,假设数据包传输每轮次需要 300 毫秒(RTT),一秒就有 3.3 个轮次,那么每秒最多能传输 256 * 1420 * 3.3 / 1024 = 1171 KB 有效数据。

默认值 256 基本上能流畅观看 720p 的 youtube 视频,如果看更高清的视频会卡顿,只要带宽允许,可把接收窗口值逐渐调大:

$ gap-proxy wnd 512

这样便把当前所有连接、新连接的接收窗口都设为 512 个包。跟 TCP 协议一样,gap-server 就能通过 ack 包的 Window 字段知道新发送窗口值。

现在每秒最多能传输 2343 KB 有效数据。

待办事项

  • FEC(前向纠错)
  • Proxifier / ProxyCap 的核心功能,强制代理不支持 SOCKS5 协议的程序

感谢及参考

许可证

MIT

gap-proxy's People

Contributors

fanpei91 avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.