【Rust日报】 CEL与Rust实现接近原生速度的解释执行

CEL与Rust实现接近原生速度的解释执行

这篇文章介绍了在构建Agentgateway时,如何优化嵌入式表达式语言CEL(Common Expression Language)的性能,使其在Rust中达到接近原生代码的执行速度。

背景与需求

  • 应用场景:需要一种嵌入式表达式语言让用户在运行时编写自定义逻辑

  • 典型用例

    • 提取日志字段(如request.headers["user-agent"]

    • 评估授权条件(如jwt.sub == "admin" || request.path == "/public"

    • 操作请求/响应字段

  • 性能要求:每个请求需要评估数百个表达式,必须足够快速

初始性能问题

使用Rust的CEL实现后,虽然功能完善,但性能存在瓶颈:

  • CEL占用10-20%的CPU

  • 性能测试结果:

    • 基线:60K QPS

    • 构建CEL上下文100次:15K QPS

    • 评估快速表达式100次:37.2K QPS

    • 评估慢速表达式100次:9K QPS

核心性能瓶颈

  1. 变量物化问题 :在每次评估前必须将原生类型(如http::Request)转换为Value类型,成本极高

  2. 堆分配开销 :所有Value对象都是堆分配的,克隆成本高

  3. 哈希查找开销:所有结构都使用哈希映射,每次字段访问约需20ns,嵌套表达式会累积延迟

优化方案:原生类型支持

作者提出的解决方案是允许CEL直接在原生Rust类型上解析字段,无需先转换为Value类型,只在最终结果时才进行转换,从而大幅减少不必要的类型转换和内存分配开销。

https://blog.howardjohn.info/posts/cel-fast/

FORTRAN 到 Rust 转换:第一部分

背景

作者对旅行者号太空探测器的图像处理产生兴趣,想要重新实现其处理流程。旅行者号于1977年发射,代码主要用FORTRAN编写。作者希望使用Rust来重新实现这个系统。

关键问题

  • SPICE工具包:NASA的SPICE是一套用于空间几何问题的数据格式、工具和API,主要用FORTRAN 77编写

  • 现有解决方案的局限

    • 从Rust调用C API会失去Rust的安全保障

    • 可能导致内存损坏和错误结果

    • 应用程序分发更复杂,移植性差

    • 严重依赖全局状态,完全不支持线程安全

    • 某些计算开销很大,无法并发运行

解决方案

作者决定将整个SPICE工具包直接从FORTRAN翻译成纯Rust代码:

  • 开发了f2rust:一个FORTRAN编译器,可以生成Rust代码

  • 创建了rsspice:50万行纯Rust代码的SPICE工具包移植版本

  • 成功通过了完整的SPICE测试套件

FORTRAN 77 介绍

文章介绍了FORTRAN 77的基本语法特点:

  • 子程序声明:使用SUBROUTINE定义函数

  • 隐式类型:默认情况下,I-N开头的变量是整数,其他是实数(可以用IMPLICIT NONE禁用)

  • 数组操作:支持多维数组

  • 循环语句:DO循环和语句标签系统

  • 代码示例:展示了一个向量加法的简单子程序

https://zaynar.co.uk/posts/f2rust-1/

--

From 日报小组 Mike

社区学习交流平台订阅:

  • Rustcc论坛: 支持rss

  • 微信公众号:Rust语言中文社区

相关推荐
为何创造硅基生物24 分钟前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好25 分钟前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
星寂樱易李34 分钟前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
仰泳之鹅1 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
之歆1 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
candyTong2 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
cen__y2 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
GetcharZp3 小时前
GitHub 2.4 万 Star!D2 正在重新定义程序员画图方式
后端
社交怪人3 小时前
【算平均分】信息学奥赛一本通C语言解法(题号2071)
c语言·开发语言