Kamailio通过Lua写路由

1、模块

app_lua(往往配合kimi框架一起使用)

官网参考资料:https://kamailio.org/docs/modules/5.7.x/modules/app_lua.html

2、版本选择

内置lua:支持5.1,5.2,5.3;

luajit:仅支持5.1,但是比内嵌解释器速度快很多;要求编译kam时带上:

复制代码
 $ LUAJIT="yes" make modules modules=modules/app_lua

3、支持方式

3.1、cfgengine(支持RPC重载)

模块参数设置lua脚本,所有路由功能交到lua处理,入口函数(固定)ksr_request_route,相当于原生脚本中的request_route。

复制代码
#全局参数#
cfgengine "lua"

#模块参数#
modparam("app_lua", "load", "/usr/local/kamailio/lua/route.lua")
Lua 复制代码
function ksr_request_route()
    ...
end

3.2、preload(支持RPC重载)

模块参数设置lua脚本,lua脚本中的非本地(local)方法会加载到内存中,cfg路由块中通过lua_run(func_name)调用;说明:lua脚本中local方法仍然可以被其他被暴露出来的非local调用。

cpp 复制代码
modparam("app_lua", "load", "/usr/local/kamailio/lua/route.lua")

request_route{
    ...
    lua_run("func1");
    if ($var(result) < 0) {
        exit;
    }
    ...
}
cpp 复制代码
function func1()
    ...
    KSR.pv.seti("$var(result)", -1);
    //KSR.pv.sets("$var(result)", "-1");
end

3.3、lua_dofile(不支持RPC重载)

cpp 复制代码
request_route{
    ...
    lua_dofile("/usr/local/kamailio/lua/init.lua");
    if ($var(result) < 0) {
        exit;
    }
    ...
}

3.4、lua_dosting(不涉及重载)

cpp 复制代码
lua_dostring("KSR.log([[err]], [[----------- Hello World from $fU\n]])");
lua_runstring("KSR.log([[err]], [[----------- Hello World from $fU\n]])");

4、关键技术点

4.1、返回值

暴露的几个lua_*方法的返回值,不是实际执行返回值,是脚本是否执行成功的结果,如果在lua脚本里面因为做了某些业务功能逻辑(比如查询某个数据),要把lua中的到的数据返回到主路由(main.cfg)种使用,技巧:通过伪变量来传值。

4.2、预编译

如果为了提高加载速度,可以进行提前预编译,比如:luac5.3 -o hello.lua hello,但是dofile就要去掉.lua后缀。

4.3、慢加载

当使用热加载功能事时(modparam("app_lua", "reload", 1)),并不是立刻更新lua文件,每次更新对于的version会加1,当真正执行到脚本时,比较发现两个version不同,此时才加载;具体为:

app_lua模块在内存中维护了一个list列表,里面存放load进来的lua【modparam("app_lua", "load", "/usr/local/etc/kamailio/lua/myscript.lua")】"信息"(关键是存放了每条数据的version信息),每次reload,version加1,启动时初始化为0,version信息也会在脚本对象中存放一份,每次执行脚本时,会比较脚本对象中的version与list中是否一致。不一致则更新lua,同时更新脚本对象中version的值。

4.4、加载方法

语法:kamcmd app_lua.reload <index>

cpp 复制代码
...
    kamcmd app_lua.reload 0
...

index的需要通过另外一个rpc命令获取,app_lua.list

相关推荐
小陈工10 分钟前
Python安全编程实践:常见漏洞与防护措施
运维·开发语言·人工智能·python·安全·django·开源
是娇娇公主~6 小时前
C++ 中 std::deque 的原理?它内部是如何实现的?
开发语言·c++·stl
SuperEugene7 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
xuxie998 小时前
N11 ARM-irq
java·开发语言
wefly20178 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
luanma1509809 小时前
PHP vs C++:编程语言终极对决
开发语言·c++·php
寂静or沉默9 小时前
2026最新Java岗位从P5-P7的成长面试进阶资源分享!
java·开发语言·面试
小虎卫远程打卡app9 小时前
光通信与视频编码前沿技术综述:从超大容量传输到实时神经网络编码
运维·网络·信息与通信·视频编解码
kyriewen119 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
娇娇yyyyyy10 小时前
QT编程(18): Qt QItemSelectionModel介绍
开发语言·qt