尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

TimescaleDB的Cross-Module Function机制

TimescaleDB的Cross-Module Function机制
📅 发布时间:2026/6/30 13:05:28

函数映射的三层结构

SQL 层: compress_chunk(sql) → 'ts_compress_chunk'(C函数名) ↓ src/cross_module_fn.c: ts_compress_chunk() → 代理/跳板函数 (Apache License) ↓ ts_cm_functions->compress_chunk(fcinfo) ↓ tsl/src/init.c: .compress_chunk = tsl_compress_chunk ← 真正的函数指针赋值 (TSL License) ↓ tsl/src/compression/api.c: tsl_compress_chunk() ← 真正的实现

第一步:SQL 声明 → C 函数名

sql/maintenance_utils.sql:40:

CREATE FUNCTION compress_chunk(...) RETURNS REGCLASS AS '@MODULE_PATHNAME@', 'ts_compress_chunk' LANGUAGE C;

第二步:跨模块代理包装器

src/cross_module_fn.c:18-23 的CROSSMODULE_WRAPPER宏:

#define CROSSMODULE_WRAPPER(func) \ TS_FUNCTION_INFO_V1(ts_##func); \ Datum ts_##func(PG_FUNCTION_ARGS) \ { \ PG_RETURN_DATUM(ts_cm_functions->func(fcinfo)); \ } CROSSMODULE_WRAPPER(compress_chunk); // 展开为 ts_compress_chunk()

展开后:

// 自动生成 ts_compress_chunk 函数! Datum ts_compress_chunk(PG_FUNCTION_ARGS) { // 通过函数指针调用真正的实现 PG_RETURN_DATUM(ts_cm_functions->compress_chunk(fcinfo)); }

ts_compress_chunk不是手动写的,是 CROSSMODULE_WRAPPER 宏自动生成的!

第三步:函数指针赋值

CrossModuleFunctions结构体在 cross_module_fn.h:131 有一个字段:

typedef struct CrossModuleFunctions { // ... PGFunction compress_chunk; // 函数指针 PGFunction decompress_chunk; // ... } CrossModuleFunctions;

在 tsl/src/init.c:176 初始化时赋值:

static CrossModuleFunctions tsl_cm_functions = { // ... .compress_chunk = tsl_compress_chunk, // 指向真正的实现! .decompress_chunk = tsl_decompress_chunk, // ... };

ts_module_init()执行时:

ts_cm_functions = &tsl_cm_functions; // 全局函数表指向 TSL 实现

为什么这样设计?双 License 架构

┌──────────────────────────────────────────────────────────┐ │ TimescaleDB 双 License 架构 │ ├──────────────────────────────────────────────────────────┤ │ │ │ src/ 目录 (Apache 2.0 License - 完全开源) │ │ ├── cross_module_fn.c ← CROSSMODULE_WRAPPER 宏 │ │ │ 生成 ts_compress_chunk() 代理函数 │ │ │ 默认函数表 → error_no_default_fn_pg_community │ │ │ (如果只装开源版,调用会报错: "not supported │ │ │ under the current license") │ │ │ │ │ └── cross_module_fn.h ← CrossModuleFunctions 结构体 │ │ │ │ tsl/ 目录 (Timescale License - 商业功能) │ │ ├── init.c ← 赋值函数表 │ │ │ .compress_chunk = tsl_compress_chunk │ │ └── compression/api.c ← 真正的实现 │ │ tsl_compress_chunk() {...} │ │ │ └──────────────────────────────────────────────────────────┘
  • Community 版(只用src/):函数表保留默认值error_no_default_fn_pg_community,压缩功能不可用
  • 完整版(加载tsl/):_PG_init()调用ts_module_init(),将ts_cm_functions指向tsl_cm_functions,所有函数指针替换为真实实现

总结

ts_compress_chunk是真实存在的 C 函数,但它不是手写的 — 它由CROSSMODULE_WRAPPER(compress_chunk)宏自动生成。它就是一张跳板,通过##宏拼接生成:

// 宏: CROSSMODULE_WRAPPER(compress_chunk) // 生成函数名: ts_##compress_chunk → ts_compress_chunk // 函数体: 调用 ts_cm_functions->compress_chunk(fcinfo) // 即 tsl_compress_chunk(fcinfo)

所有以ts_开头、tsl_实现的功能(压缩、解压缩、连续聚合、压缩策略等),都走这套CROSSMODULE_WRAPPER→ts_cm_functions函数表 → TSL 实现的路径。

相关新闻

  • 3个技巧解决Python数据采集中的Cookie验证难题
  • 毕设实战:从Proteus仿真到PCB制板的51单片机数字电压表全流程解析
  • macOS微信防撤回终极指南:3分钟快速安装完整教程

最新新闻

  • Vivado IBERT实战:从眼图分析到误码率调优的硬件调试指南
  • 【硬件设计实战】JTAG接口上下拉电阻配置全解析:从标准到芯片手册
  • 误删微信聊天记录不用愁,全套官方恢复教程,文末科普第三方渠道
  • Spring AOP(XML配置版):代理机制与拦截器
  • Kali Linux实战:SQL注入与XSS漏洞攻防演练
  • 泰国华商出海数字化选型解析:国内大厂、本土软件与出海专属系统对比(批发 / 零售业态专属)

日新闻

  • 【计算机毕业设计案例】基于 Spring Boot+Vue 的电影售票系统设计与实现 前后端分离架构下影院在线购票管理平台(程序+文档+讲解+定制)
  • 到底 TMD 用哪个: npm, pnpm, Yarn, Bun, Deno? 傻瓜, 当然用 npm 啦
  • Google限制Meta使用Gemini模型 凸显AI授权竞争白热化

周新闻

  • Windows字体自定义终极方案:No!! MeiryoUI完全指南
  • Deepin Boot Maker:告别命令行,3分钟制作Linux启动盘的智能解决方案
  • Plain Craft Launcher 2:重新定义你的Minecraft游戏体验

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号