2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

都推进到 95% 了,为什么 curl 还是放弃基于 Rust 开发了四年的 HTTP 后端替代

  • 2024-12-25
    北京
  • 本文字数:1925 字

    阅读完需:约 6 分钟

都推进到95%了,为什么curl还是放弃基于Rust开发了四年的HTTP后端替代

“实验结束了。我们努力了,但还是失败了。”


近日,知名开源项目 curl 的创始人 Daniel Stenberg 正式发文宣布,将放弃对基于 Rust 编写的 Hyper HTTP 后端的支持,并彻底移除相关代码


“四年前,我们开始在 curl 中添加对另一种 HTTP 后端的支持。它将使用一个基于 Rust 编写的库,名为 Hyper。我们的想法是引入一种替代的 HTTP 内部实现,让 curl/libcurl 使用它来代替本地实现。”Stenberg 在博客中写道。然而,这场实验在历经四年的努力后,以失败告终。

完成 95% 的工作只是开始?


这一尝试始于 2020 年,由 ISRG(Let’s Encrypt 背后组织)资助。当时的目标是通过 Rust 的内存安全特性,为 curl 用户提供一个更安全的 HTTP 后端实现。Stenberg 在早期的博客中写道。“通过 Hyper,我们能够让更多代码运行在内存安全语言中,而非完全依赖 C。”


尽管实验已经推进了一大半,甚至让 Hyper 后端通过了几乎所有测试用例,但如同 Stenberg 在最新的博文中所述,“我们完成了 95% 的开发工作,然而,最后那‘百分之几’的挑战,还是让我们不得不认输,放弃这个实验。”


目前来看,实验失败的两大关键原因如下:

  • 几乎没人有这需求:curl 的用户对 Hyper 没有兴趣;Hyper 的用户也不太关心让它兼容 curl。

  • 缺乏同时精通 C 和 Rust 的开发者来推进:Hyper 是用 Rust 写的,而 libcurl 库(curl 背后的“引擎”)是用 C 写的,需要一个“胶水层”来把它们连接起来。这需要开发者不仅对两种语言精通,还要深入理解它们的架构和协议,但目前没有合适的人去做这件事。


此外,早在 2020 年开始这个实验时,Stenberg 就提到过“Hyper 没有 C API”是一个棘手的挑战。

停滞与反思:Hyper 成为“负担”


在今年 4 月的另一篇推文中,Stenberg 就预示过这次实验的结局,他提出了发人深省的问题:“Hyper 支持是否值得继续?”——当时,Hyper 后端的开发工作已陷入停滞,过去半年内几乎没有人主动对其进行功能改进或优化。与此同时,用户对 Hyper 的需求仍然冷淡。


技术上,Hyper 后端的开发过程中还出现了多次反向调整。例如,例如,由于对 Hyper API 集成方式的理解偏差,而不得不移除对 HTTP/2 的支持,这直接导致无法正确实现 HTTP/2 的功能。


更大的问题在于,社区用户的需求和兴趣严重失衡:当下 Rust 用户更愿意直接使用 Hyper,而不是帮助让它支持 C 项目;而 curl 的现有用户对 Hyper 几乎没有兴趣。


社区中这两类用户的交集太小,已经无法为 Hyper 后端的持续开发提供足够的支撑。


面对多重困难,Stenberg 开始反思:“Hyper 的支持是否已经从一种探索创新的尝试,变成了拖累改进的负担?”显然,继续维护这一功能的成本已经超过了它的实际价值。


既然在短、中期内都看不到完成的希望,与其继续耗费资源,不如果断放弃——移除这部分代码,不仅可以大幅简化项目结构,还能提高整体的灵活性,为 curl 的未来发展留出更多空间。

用其他语言重写 curl?也几乎不可能


或许会有人提问,当初为什么不直接用 Rust 重写 curl 呢?Stenberg 早就明确表示,这从来不在他们的计划之中。


一方面,curl 是一个老牌开源软件,已经运行了 25 年。对于 libcurl 用户来说,稳定的接口(API)、应用二进制接口(ABI)、一致的行为,以及文档中定义的所有功能选项,都是不可动摇的基础。重写代码不仅意味着要重新开发所有功能,还需要确保新版本完全兼容旧版,这对任何项目来说都是一项巨大而复杂的挑战。即使是那些考虑过这样做的大型企业,最终也都放弃了这个想法。


与此同时,Stenberg 等人也深知,curl 必须不断引入新功能,才能跟上技术的发展步伐。于是,Hyper 后端支持方案成为他们探索的方向。


虽然 Hyper 实验以失败告终,但它对 curl 和 Hyper 项目都带来了积极影响。Stenberg 表示,curl 在与 Hyper 集成的过程中,改进了自身对 HTTP 的严格性,并优化了代码结构,而 Hyper 则通过与 curl 的合作获得了宝贵的反馈,进一步提升了自身的稳定性和性能。


他强调:“虽然 Hyper 已被移除,但我们依然对未来引入 Rust 或其他语言的安全后端持开放态度。与 2020 年那会相比,我们现在已经拥有了更好的内部架构可供借鉴。只要用户需求足够明确,并且有足够的资源支持,我们还可能会重新尝试类似的整合。”


尽管 Hyper 被放弃,curl 仍然在推进对两个 Rust 编写的后端的支持::rustls(用于 TLS)和 quiche(用于 QUIC 和 HTTP/3),它们被认为比 Hyper 更易于维护。


据悉,Hyper 的相关代码已于 2024 年 12 月 21 日从 curl 的代码库中删除,并将在 2025 年 2 月发布的 curl 8.12.0 版本中完全失效。


参考链接:

https://daniel.haxx.se/blog/2024/12/21/dropping-hyper/

https://daniel.haxx.se/blog/2020/10/09/rust-in-curl-with-hyper/

https://curl.se/mail/lib-2024-04/0021.html

2024-12-25 17:1111481

评论 2 条评论

发布
用户头像
行百里者半九十的经典案例。

尽管实验已经推进了一大半,甚至让 Hyper 后端通过了几乎所有测试用例,但如同 Stenberg 在最新的博文中所述,“我们完成了 95% 的开发工作,然而,最后那‘百分之几’的挑战,还是让我们不得不认输,放弃这个实验。”

2024-12-26 18:46 · 北京
回复
用户头像
用其它语言来实现curl,不是不可能,而是没有必要。
2024-12-26 17:42 · 陕西
回复
没有更多了

VMware Fusion 专业版 v13.6.3 中文版 附激活码

Rose

区块链NFT系统的上线流程

北京木奇移动技术有限公司

区块链技术 软件外包公司 音乐NFT

CST的涡流制动 - CSTOpera仿真对比

思茂信息

cst CST软件 CST Studio Suite

我用大模型砌“屎山雕花”:5天肝出几万行代码!产品经理的AI编程翻车记

金松(李博源)

大模型 AI 编程

分析师:对英特尔未来发展持谨慎乐观态度

E科讯

Moho pro 13下载安装教程 附Moho pro 13中文激活补丁-Mac/win

Rose

苹果Mac电脑必备翻译软件 Eudic欧路词典 增强版

Rose

Jump Desktop v9.1.9 mac远程桌面控制 支持RDP、VNC协议

Rose

深入研究:shopee商品列表API接口指南

tbapi

shopee商品列表接口 shopee数据采集 shopee接口

视觉与图像识别自动化测试 | 文字转语音

测试人

人工智能

家政到家服务平台(源码+文档+讲解+演示)

深圳亥时科技

Safari视频扩展插件OverPicture 支持HTML5格式

Rose

通义灵码 AI IDE 上线!智能体+MCP 从手动调用工具过渡到“AI 主动调度资源”

阿里巴巴云原生

通义灵码

由 Mybatis 源码畅谈软件设计(九):“能用就行” 其实远远不够

京东科技开发者

就医体验飙升的背后,是CPU在“悄悄打工”?

E科讯

【Mac/win】Axure RP 8授权密钥+Axure RP 8离线激活教程

Rose

大促数据库压力激增,如何一眼定位 SQL 执行来源?

京东科技开发者

Parallels虚拟机必备:Parallels Toolbox 工具箱合集

Rose

准确率从 19% 提升至 95%!文本审核模型优化的三个阶段实践(下)

亚马逊云科技 (Amazon Web Services)

通义灵码 AI IDE 上线!智能体+MCP 从手动调用工具过渡到“AI 主动调度资源”

阿里云云效

ide 通义灵码

如何判断两张图片的相似度?原来图片对比也可以如此简单!

左诗右码

哪里有Principle 汉化版?Principle mac中文资源分享

Rose

智驾安全,发展到哪一步了?

脑洞汽车

AI

数字藏品(NFT)系统的上线运营

北京木奇移动技术有限公司

区块链技术 软件外包公司 音乐NFT

员工反感的不是周报,而是消耗人的形式化

禅道项目管理

项目管理 数字化转型 周报 禅道项目管理软件

区块链NFT系统的类型及特点

北京木奇移动技术有限公司

区块链技术 软件外包公司 NFT系统

Archicad 28最新的改进,使用设计更加舒适和高效

Rose

三维高级渲染工具Artlantis 2021一键激活版-mac/win

Rose

前端开发中依赖包有问题怎么办

京东科技开发者

开发十年现状之后端的职业发展

秃头小帅oi

mac磁盘分区工具 Paragon Hard Disk Manager

Rose

都推进到95%了,为什么curl还是放弃基于Rust开发了四年的HTTP后端替代_后端_罗燕珊_InfoQ精选文章