操作系统 :CentOS 7.6_x64
opensips版本: 2.4.9
python版本:2.7.5
python作为脚本语言,使用起来很方便,查了下opensips的文档,支持使用python脚本写逻辑代码。今天整理下CentOS7环境下opensips2.4.9的python模块笔记及使用示例,并提供运行效果视频和配套文件下载。
我将从以下几方面进行展开:
-
模块安装说明
-
模块参数说明
-
模块函数说明
-
模块使用示例
python模块官方文档:
https://opensips.org/docs/modules/2.4.x/python.html
data:image/s3,"s3://crabby-images/32169/321696928ba526ecbc0ac6d8866f5557c716e382" alt=""
一、模块安装说明
1)安装python开发库
yum install python-devel.x86_64
2)进入opensips源码目录
cd opensips-2.4.9
3)选中 python 模块
make menuconfig
data:image/s3,"s3://crabby-images/bf4d9/bf4d91422ebce1548f98e0e693e976095ea861a2" alt=""
4)编译及安装opensips
make && make install
data:image/s3,"s3://crabby-images/ebf00/ebf00b00e538eefe125c0cc1ad5a8aa3c5ae2a83" alt=""
CentOS7环境下源码安装opensips,可参考如下文章:
二、模块参数说明
模块文件: python.so
模块参数如下:
-
script_name
用于设置python脚本的路径。
-
mod_init_function
用于设置python脚本的初始化函数,默认是mod_init
-
child_init_method
用于设置python脚本的子进程(子类)的初始化函数,默认是child_init
模块加载及配置数据库
文件:opensips.cfg
配置示例:
#### python module
loadmodule "python.so"
modparam("python", "script_name", "/usr/local/etc/opensips/op-test1.py")
#modparam("python", "mod_init_function", "module_initializer")
#modparam("python", "child_init_method", "child_initializer")
三、函数说明
1、cfg文件调用函数
函数: python_exec
python_exec(method_name [, extra_args])
该函数调用python脚本里面的方法。
2、python脚本内部调用函数
2.1 LM_ERR函数
在python里面,opensips作为独立的模块,导出了LM_ERR函数,定义如下(python_iface.c):
data:image/s3,"s3://crabby-images/ce936/ce936a83b43ca9db4fe0d85b23581c02dccf0279" alt=""
该函数用于打印日志,示例如下:
LM_ERR('test msg from python')
2.2 sip msg相关属性及方法
属性定义如下(python_msgobj.c):
data:image/s3,"s3://crabby-images/4e287/4e287312ca711da52268c59183897260f469fd84" alt=""
方法定义如下(python_msgobj.c):
data:image/s3,"s3://crabby-images/cb077/cb077bce86483265e8cb72fe785b04327e4ca1c9" alt=""
-
Type
msg的类型,SIP_REQUEST 或 SIP_REPLY
-
Method
msg的方法,比如:"INVITE"
-
Status
msg的状态,只适用于reply
-
RURI
msg的R-URI,只适用于request
-
src_address
msg的源地址信息
-
dst_address
msg的目的地址信息
-
copy()
复制当前SIP消息
-
rewrite_ruri(uri)
修改msg的request URI,仅适用于request
-
set_dst_uri(uri)
修改msg的destination URI ,仅适用于request
-
getHeader(hdr)
获取SIP头的具体内容
-
call_function(funName,...)
调用其它模块的函数
四、使用示例
这里演示下python模块的加载,及使用该模块进行简单测试。
1、打印日志
使用LM_ERR函数进行日志打印。
示例代码(op-test1.py):
from OpenSIPS import LM_ERR
class ObjA():
def child_init(self,rank):
return 0
def pytest1(self,var1):
LM_ERR("test msg from python script")
return 1
def mod_init():
return ObjA()
opensips.cfg配置如下:
#### python module
loadmodule "python.so"
modparam("python", "script_name", "/usr/local/etc/opensips/op-test1.py")
#modparam("python", "mod_init_function", "module_initializer")
#modparam("python", "child_init_method", "child_initializer")
####### Routing Logic ########
# main request routing logic
route{
if(python_exec("pytest1")) {
xlog("python test1 return true\n");
}
exit;
运行效果如下:
data:image/s3,"s3://crabby-images/bed35/bed354a7d4ed884a68a5a85de578ddef84f663b9" alt=""
运行效果视频可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 2024042301 获取。
2、调用其它模块函数
示例代码及配置可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240423 获取。
运行效果如下:
data:image/s3,"s3://crabby-images/bb18e/bb18e4ae2571b29aa77b5131ceb364ba50d1d2f4" alt=""
运行效果视频可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 2024042302 获取。
3、实现呼叫路由
这里演示下python调用drouting模块函数实现话务路由的功能。
机器列表:
freeswitchA :192.168.137.31:5080
opensips :192.168.137.33:5060
freeswitchB :192.168.137.32:5080
测试目标:将freeeswitchA呼叫opensips的通话路由到freeswitchB机器。
拨号方案等信息参考如下文章:
示例代码及配置可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240423 获取。
运行效果如下:
data:image/s3,"s3://crabby-images/65ecb/65ecb54e8e53ddf678c75da87d8fd6eb1f40b2d7" alt=""
抓包效果如下:
data:image/s3,"s3://crabby-images/a9c35/a9c35952af60636d8b5f4bdcde2fca9bc08d0d5e" alt=""
运行效果视频可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 2024042303 获取。
五、资源下载
本文涉及资源,可以从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240423 获取。
data:image/s3,"s3://crabby-images/9fb90/9fb90f29aeb68df47e5cd89b910e294de0a4b506" alt=""
好,就这么多了,别忘了点赞哈!