Asterisk拨号方案Dialplan支持Redis操作

本文介绍了在Asterisk拨号方案中使用func_redis模块替代AstDB,以解决数据库锁定问题。详细阐述了func_redis模块的功能,并提供了将其移植到Asterisk源代码内的步骤,包括安装依赖库、修改源代码、配置编译选项等过程。
摘要由CSDN通过智能技术生成

一、概述

当我们编写Asterisk拨号方案时经常会使用Asterisk自带的Sqlite数据库(Key-Value型数据库)进行读写变量,这为我们带来了很大的方便。但也经常会遇到报错:WARNING[2734]: db.c:304 db_execute_sql: Error executing SQL (COMMIT): database is locked。提示AsteriskDB被锁住了,究其原因大致是多处同时写入astdb.sqlite3可能会造成“database is locked”的死锁。比如在点击Web生成拨打方案时会操作数据库(写AstDB,database put),而此时又正在刷PJSIP分机和中继状态信息。AstDB(astdb.sqlite3)不仅要存放注册分机和中继的状态信息(asterisk  -rx 'database show'查看那些Key键是registrar/contact),还要存放数据记录。这个概率出现比较高。出现此问题时一般的解决办法有3个:

  1. 重新启动系统。
  2. 停止Asterisk,然后删除 /var/lib/asterisk/astdb.sqlite3(前提是此数据库没有存放数据记录)
  3. 将AstDB dump出来,然后停止asterisk,再还原回去。命令为
#sqli
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值