[asterisk-dev] [Code Review] 3559: sqlite3: Add ability to automatically retry query to busy database
Matt Jordan
reviewboard at asterisk.org
Tue May 27 09:35:21 CDT 2014
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://reviewboard.asterisk.org/r/3559/#review11973
-----------------------------------------------------------
/trunk/cdr/cdr_sqlite3_custom.c
<https://reviewboard.asterisk.org/r/3559/#comment21884>
So, I'm definitely a fan of using the busy timeout rather than this arbitrary polling (which, as the comment suggests, is ... not good).
I do think we should be handling the return code from sqlite3_exec here however, rather than simply relying on something being in error:
res = sqlite3_exec(db, sql, NULL, NULL, &error);
if (res != SQLITE_OK) {
ast_log(LOG_ERROR, "%s. SQL: %s.\n", error, sql);
sqlite3_free(error);
}
/trunk/cel/cel_sqlite3_custom.c
<https://reviewboard.asterisk.org/r/3559/#comment21885>
And handle the error here as well
/trunk/main/db.c
<https://reviewboard.asterisk.org/r/3559/#comment21886>
This one is the only usage that concerns me, simply because small changes in the AstDB code could have unforeseen effects.
Have you run into a situation where the AstDB had similar problems under high load?
- Matt Jordan
On May 22, 2014, 1:29 p.m., Igor Goncharovsky wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://reviewboard.asterisk.org/r/3559/
> -----------------------------------------------------------
>
> (Updated May 22, 2014, 1:29 p.m.)
>
>
> Review request for Asterisk Developers.
>
>
> Bugs: ASTERISK-23766
> https://issues.asterisk.org/jira/browse/ASTERISK-23766
>
>
> Repository: Asterisk
>
>
> Description
> -------
>
> We have faced situation when using CDR and CEL by sqlite3 modules. With system having high load (~100 concurrent calls created by sipp) we found many cdr and cel records missed. There is special finction in sqlite3, that make able to fix this situation - sqlite3_wait_timeout, that also can replace awful code cdr_sqlite3 ad cel_sqlite3 modules. Also this function can be used for aastdb and res_config_sqlite3 to avoid missed writes to sqlite db.
>
>
> Diffs
> -----
>
> /trunk/res/res_config_sqlite3.c 414121
> /trunk/main/db.c 414121
> /trunk/cel/cel_sqlite3_custom.c 414121
> /trunk/cdr/cdr_sqlite3_custom.c 414121
>
> Diff: https://reviewboard.asterisk.org/r/3559/diff/
>
>
> Testing
> -------
>
> Adding sqlite3_wait_timeout already used as patch in AskoziaPBX and show good result.
>
>
> Thanks,
>
> Igor Goncharovsky
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-dev/attachments/20140527/31740202/attachment-0001.html>
More information about the asterisk-dev
mailing list