一、概述
当我们编写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个:
- 重新启动系统。
- 停止Asterisk,然后删除 /var/lib/asterisk/astdb.sqlite3(前提是此数据库没有存放数据记录)
- 将AstDB dump出来,然后停止asterisk,再还原回去。命令为
#sqli