【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语言中文社区

相关推荐
Rain5094 分钟前
2.1 Nest.js 项目初始化与模块化架构
开发语言·前端·javascript·后端·架构·数据分析·node.js
cjp5608 分钟前
009. ASP.NET WEB API 用户关联esp32设备
前端·后端·asp.net
贺国亚15 分钟前
Text-to-SQL与Analytics-Agent
后端
小熊美家熊猫系统23 分钟前
电子合同技术实现与合规实践
java·开发语言·分布式
ytttr87326 分钟前
C# 定时数据库备份工具
开发语言·数据库·c#
一只叫煤球的猫33 分钟前
ThreadForge 源码解读二:一个 Task 从 submit 到完成,内部到底发生了什么?
java·后端·面试
苏三说技术1 小时前
AgentScope Java 2.0 正式发布了!
后端
skywalk81631 小时前
言知项目后续方向建议
开发语言·学习·编程
ping某1 小时前
一个“日志备份”需求,为什么会牵出整个 Linux 日志系统?
后端·架构
血小溅1 小时前
Spring AI 对 Skill/MCP 的支持全景整理
后端