参考这个issue:
https://github.com/kamailio/kamailio/issues/4578
目前的 app_lua 是基于 lua5.1 编译的,不好!
在 Debian/Ubuntu 系统上,官方软件源同时提供多个 Lua 版本及其开发库(liblua5.1、liblua5.2、liblua5.3、liblua5.4 等),
而 Kamailio 的 app_lua 模块目前只针对其中一个版本(主要是 liblua5.1)编译打包。
如果打包者把 app_lua 改链接到较新的 Lua 版本(如 5.3 或 5.4),就会破坏依赖旧版本 Lua 的用户的兼容性。
因此提出一个方案: 让 app_lua 模块可以多次编译,针对每个 Lua 版本生成一个独立的 .so 文件,例如:
app_lua.so → 链接最新的稳定版(推荐默认使用)
app_lua52.so → 链接 Lua 5.2
app_lua53.so → 链接 Lua 5.3
app_lua54.so → 链接 Lua 5.4
......
用户/打包者根据实际环境加载对应的模块版本,避免单一版本打包导致的大范围兼容性问题。
技术实现思路(讨论中提到的)
通过 CMake 编译时传入参数控制模块的内部名称,例如:
-DMOD_NAME='"app_lua54"'
这样生成的共享库文件名和注册的模块名都会带上版本标记。
打包时可以把多个变体放到同一个 kamailio-app-lua 或 kamailio-lua 包里,或者拆分成独立的子包(视打包策略而定)。
对比了 tls/tlsa 的处理方式(把 tls 代码嵌入 tlsa),但认为 不适合 直接套用到 app_lua 上,因为 Lua 版本兼容性问题更普遍且长期存在。