kcptun 数据传输工具 kcptun

agolangf2016-04-20 16:00:00 • 10497 次点击    
这是一个分享于 2016-04-20 16:00:00 的项目,其中的信息可能已经有所发展或是发生改变。

kcptun

TCP流转换为KCP+UDP流,用于高丢包 环境中的数据传输,工作示意图:

+---------------------------------------+
                |                                       |
                |                KCPTUN                 |
                |                                       |
+--------+      |  +------------+       +------------+  |      +--------+
|        |      |  |            |       |            |  |      |        |
| Client | +--> |  | KCP Client | +---> | KCP Server |  | +--> | Server |
|        | TCP  |  |            |  UDP  |            |  | TCP  |        |
+--------+      |  +------------+       +------------+  |      +--------+
                |                                       |
                |                                       |
                +---------------------------------------+

kcptun可以用于任意tcp网络程序的传输承载,可以极大的提高软件网络流畅度,降低掉线,连不上等情况。

特性

1. 超级快

2. 采用高安全性AES-256-CFB加密,双重加密

3. UDP数据包一次一密(OTP),无特征,防非法深度检测

4. 消息摘要采用MD5,杜绝非法篡改

5. kcptun客户端和服务端分别只有一个main.go文件,易于使用

6. 核心基于kcp-go

7. 基于yamux 的多路流复用( N:1 ------ > 1:N)

加密流程:

rand.Reader
                                     +
+-----------+                        |
|           |                        |                 +---------+   PSK   +-----------+
| PLAINTEXT |                     +--v--+              |                               |
|           |                     | OTP |              |                               |
+-----+-----+                     +--+--+              |                               |
      |                              |                 |                               |
 +----v----+    +--------+       +---v----+       +----+----+                     +----+----+        +--------+                      +-----------+
 |         |    |        |       |        |       |         |                     |         |        |        |                      |           |
 | AES-CFB +----> CIPHER +-------> PACKET +-------->AES-CFB +----> Internet +------>AES-CFB +--------> PACKET |                      | PLAINTEXT |
 | ENCRYPT |    |  TEXT  |       |        |       | ENCRYPT |                     | DECRYPT |        |        |                      |           |
 |         |    |        |       +---^----+       |         |                     |         |        +---+----+                      +-----^-----+
 +----^----+    +---+----+           |            +---------+                     +---------+            |                                 |
      |             |           +----+----+                                                              |                                 |
      |             |           |         |                                                          +---v----+       +--------+      +----+----+
      |             +----------->   MD5   |                                                          |        |       |        |      |         |
      |                         |         |                                                          |  MD5   +-------> CIPHER +------->AES-CFB |
      |                         +---------+                                                          | VERIFY |       |  TEXT  |      | DECRYPT |
      |                                                                                              |        |       |        |      |         |
      |                                                                                              +--------+       +--------+      +----^----+
      |                                                                                                                                    |
      |                                                                                                                                    |
      +---------------------------------------------------------+    PSK   +---------------------------------------------------------------+

适用范围(包括但不限于):

1. 网络游戏的数据传输

2. 跨运营商的流量传输

3. 其他高丢包,高干扰通信环境的TCP数据传输

快速上手

注意,请确保默认服务器端UDP端口 29900 开启,防火墙允许UDP包通过。 (端口可以通过命令行参数调整,不要忘记修改对应的防火墙规则。)

这里 下载最新的对应平台的版本(内含x86/x64/arm), 执行 client -h 和server -h 查看详细使用方法.
我们以加速ssh -D访问为例示范使用方法如下:

1. 假定服务器IP为:xxx.xxx.xxx.xxx

2. 在服务器端开启ssh -D (监听127.0.0.1:8080端口,或者你可以在服务器端启动任意的socks代理监听127.0.0.1:8080 )ssh -D 127.0.0.1:8080 ubuntu@localhost

3. 在服务器启动kcp server:server -t "127.0.0.1:8080" // 所有数据包转发到sshd进程的socks 8080端口

---------------------------- 分割线,上面是服务器,下面是客户端 ----------------------------

4. 在本地启动kcp client:client -r "xxx.xxx.xxx.xxx:29900" // 连接到kcp server,默认kcp server端口是29900

5. 浏览器就可以连接12948端口进行socks5代理访问了。 // 默认kcp client的端口是12948

从源码的安装

预备条件:

1. 安装好golang

2. 设置好GOPATH 以及PATH=$PATH:$GOPATH/bin (例如: export GOPATH=/home/ubuntu; export PATH=$PATH:$GOPATH/bin), 最好放到.bashrc 或 .zshrc中

安装命令

1. 服务端: go get github.com/xtaci/kcptun/server; server

2. 客户端: go get github.com/xtaci/kcptun/client; client

常见问题

Q: client/server都启动了,但无法传输数据,服务器显示了stream open
A: 先杀掉client/server,然后重新启动就能解决绝大部分的问题

Q: client/server都启动了,但服务器没有收到任何数据包也没有stream open
A: 某些IDC默认屏蔽了UDP协议,需要在防火墙中打开对应的端口

Q: 出现不明原因降速严重,可能有50%丢包
A: 可能该端口被运营商限制,更换一个端口就能解决

另外,一些比较有代表性的issue可以参考:
https://github.com/xtaci/kcptun/issues/2

参数调整

初步运行成功后,强烈建议通过命令行改变如下参数加强传输安全:

  1. 默认端口
  2. 默认密码 必须修改
    例如:
    server -l ":41111" -key "hahahah"

免责申明

用户以各种方式使用本软件(包括但不限于修改使用、直接使用、通过第三方使用)的过程中,不得以任何方式利用本软件直接或间接从事违反中国法律、以及社会公德的行为。
对免责声明的解释、修改及更新权均属于作者本人所有。

---------------------------- 分割线,上面是服务器,下面是客户端 ----------------------------

A Quantum-Safe Secure Tunnel based on QPP, KCP, FEC, and N:M multiplexing.Read More

Latest commit to the master branch on 4-17-2025
Download as zip
授权协议:
MIT
开发语言:
Google Go 查看源码»
操作系统:
跨平台
10497 次点击  ∙  1 赞  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传