Envoy WASM网络过滤器与访问日志数据传递实践
2025-05-07 14:25:31作者:谭伦延
背景介绍
在Envoy代理的实际应用中,开发者经常需要将WASM网络过滤器提取的数据传递到Envoy的访问日志中。本文通过一个LDAP代理的案例,深入探讨了如何实现这一功能的技术细节和解决方案。
技术挑战
在Envoy的WASM网络过滤器中提取客户端数据后,开发者面临将这些数据传递到访问日志的挑战。常见的问题包括:
- 数据在WASM过滤器中被正确提取,但无法在访问日志中显示
- 使用DYNAMIC_METADATA和FILTER_STATE机制时遇到困难
- 数据格式和访问日志配置不匹配
解决方案详解
1. WASM过滤器数据设置
在Rust实现的WASM过滤器中,正确的数据设置方式应该使用set_property方法。该方法会自动添加"wasm."前缀到过滤状态键中。例如:
self.set_property(vec!["filter_state", "ldap_ou"], Some(ou_value.as_bytes()));
self.set_property(vec!["filter_state", "ldap_dc"], Some(dc_value.as_bytes()));
self.set_property(vec!["filter_state", "ldap_samaccountname"], Some(sam_value.as_bytes()));
2. 访问日志配置
在Envoy配置文件中,访问日志部分需要正确引用这些过滤状态值。关键点在于:
- 必须使用
FILTER_STATE而非DYNAMIC_METADATA - 键名前需要添加"wasm."前缀
示例配置:
access_log:
- name: envoy.access_loggers.file
typed_config:
"@type": "type.googleapis.com/envoy.extensions.access_loggers.file.v3.FileAccessLog"
path: "/var/log/envoy/ldap_access.log"
json_format:
timestamp: "%START_TIME%"
client_ip: "%DOWNSTREAM_REMOTE_ADDRESS%"
upstream_host: "%UPSTREAM_HOST%"
bytes_received: "%BYTES_RECEIVED%"
bytes_sent: "%BYTES_SENT%"
connection_id: "%CONNECTION_ID%"
ldap:
ou: "%FILTER_STATE(wasm.ldap_ou)%"
dc: "%FILTER_STATE(wasm.ldap_dc)%"
samaccountname: "%FILTER_STATE(wasm.ldap_samaccountname)%"
常见问题排查
- 数据未显示:检查WASM过滤器是否在正确的时机设置了属性值
- 显示为"-":确认键名前缀是否正确添加了"wasm."
- 格式错误:确保访问日志配置使用了正确的JSON格式
最佳实践建议
- 在WASM过滤器中设置数据时,考虑添加默认值处理逻辑
- 使用结构化的JSON格式记录访问日志,便于后续分析
- 在开发阶段,同时监控Envoy的调试日志和访问日志,便于问题定位
总结
通过正确使用Envoy的WASM过滤器和访问日志机制,开发者可以有效地将网络层提取的数据传递到访问日志中。关键在于理解过滤状态的命名规则和访问日志的引用方式。本文提供的解决方案已在LDAP代理场景中得到验证,可适用于类似的数据传递需求。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0116
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
项目优选
收起
暂无描述
Dockerfile
763
4.97 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
856
1.92 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
677
1.33 K
Ascend Extension for PyTorch
Python
719
875
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
455
437
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.07 K
1.09 K
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
150
252
CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。
Jupyter Notebook
297
116
昇腾LLM分布式训练框架
Python
178
220