Project Icon

tcp-brutal

将Hysteria的Brutal算法移植到TCP的Linux内核模块

TCP Brutal是一个Linux内核TCP拥塞控制模块,将Hysteria的Brutal算法引入TCP协议。它通过sockopt设置带宽,兼容现有TCP代理协议,但需要客户端和服务器支持。适用于已知连接带宽的场景,尤其适合多路复用协议。该模块无需sysctl配置,不建议设为默认拥塞控制。作为Hysteria官方子项目,TCP Brutal与Hysteria保持同步更新。

TCP Brutal

TCP Brutal 是将 Hysteria 的拥塞控制算法移植到 TCP 的 Linux 内核模块。关于 Brutal 本身的信息可以在 Hysteria 文档中找到。作为 Hysteria 的官方子项目,TCP Brutal 会与 Hysteria 中的 Brutal 实现保持同步更新。

中文文档:README.zh.md

用户指南

安装脚本:

bash <(curl -fsSL https://tcp.hy2.sh/)

手动编译和加载:

# 确保已安装内核头文件
# Ubuntu: apt install linux-headers-$(uname -r)
make && make load

需要内核版本 4.9 或更高,推荐 5.8 或更高版本。如果您的内核版本早于 5.8,则仅支持 IPv4。 (缺少导出符号 tcpv6_prot)

⚠️ 警告 对于内核版本低于 4.13 的系统,您必须手动启用 fq pacing(tc qdisc add dev eth0 root fq pacing),否则 TCP Brutal 将无法正常工作。

我需要新的代理协议吗?

不需要。TCP Brutal 支持所有现有的 TCP 代理协议,但需要客户端和服务器软件的支持(提供带宽选项、交换带宽信息等)。请询问您使用的代理软件的开发者是否可以添加支持。

速度测试

示例目录包含一个简单的 Python 速度测试服务器和客户端。使用方法:

# 服务器,监听 TCP 端口 1234
python server.py -p 1234

# 客户端,连接到 example.com:1234,请求 50 Mbps 的下载速度
python client.py -p 1234 example.com 50

我需要配置 sysctl 吗?/ 我可以将 TCP Brutal 设置为系统默认的拥塞控制算法吗?

不需要,也不应该这样做。与 BBR 不同,TCP Brutal 只有在程序使用特殊的 sockopt 设置带宽时才能正常工作,而大多数程序除非另有说明,否则不支持这一功能。将其设置为默认拥塞控制算法会将所有连接的速度降至 1 Mbps。支持它的程序会自行切换到使用 TCP Brutal 拥塞控制。

开发者指南

此内核模块向系统添加了一个新的 "brutal" TCP 拥塞控制算法,程序可以使用 TCP_CONGESTION sockopt 来启用它。

s.setsockopt(socket.IPPROTO_TCP, TCP_CONGESTION, "brutal".encode())

设置发送速率和拥塞窗口增益(我们建议默认值为 1.5 到 2 倍,表示为 15/20,因为内核不支持浮点数):

struct brutal_params
{
    u64 rate;      // 每秒发送字节数
    u32 cwnd_gain; // CWND 增益(十分之一,10=1.0)
} __packed;
TCP_BRUTAL_PARAMS = 23301

rate = 2000000 # 2 MB/s
cwnd_gain = 15
brutal_params_value = struct.pack("QI", rate, cwnd_gain)
conn.setsockopt(socket.IPPROTO_TCP, TCP_BRUTAL_PARAMS, brutal_params_value)

代理开发者指南(重要)

与 Hysteria 类似,Brutal 设计用于用户知道其连接带宽的环境,因为这些信息对 Brutal 的工作至关重要。虽然 Hysteria 的协议考虑到了这一点,但目前现有的 TCP 代理协议(在撰写本文时)都没有这样的机制来在客户端和服务器之间交换带宽信息,使客户端能够告诉服务器应该以多快的速度发送数据,反之亦然。

为了解决这个问题,我们建议使用"目标地址"字段,这在每个代理协议中都有不同形式的存在。支持 TCP Brutal 的客户端和服务器可以使用特殊地址(例如 _BrutalBwExchange)来表示它们想要交换带宽信息。例如,客户端可以创建一个 _BrutalBwExchange 连接请求,如果服务器接受,就可以使用该连接与服务器交换带宽信息。

以下链接展示了这在 sing-box 中的实现方式:

https://github.com/SagerNet/sing-mux/commit/6b086ed6bb0790160de73b16683e75efe2220a79

关于 TCP Brutal 速率设置的一个重要方面是,它适用于每个单独的连接。**这使得它只适用于支持多路复用(mux)的协议,这允许客户端将所有代理连接合并到一个 TCP 连接中。**对于需要为每个代理连接使用单独连接的协议,如果同时有多个连接活动,使用 TCP Brutal 会使接收方不堪重负。

兼容性

TCP Brutal 只是 TCP 的一种拥塞控制算法,不会改变 TCP 协议本身。客户端和服务器可以单方面使用 TCP Brutal。拥塞控制算法控制数据的发送,由于代理用户通常下载的数据远多于上传的数据,仅在服务器端实施 TCP Brutal 就能获得大部分好处。(使用 TCP Brutal 的客户端可以获得更好的上传速度,但许多用户使用 Windows、MacOS 或手机,在这些平台上安装内核模块并不实际。)

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号