[sr-dev] [SR-Users] Testing dialog module (and acc with dialog cdrs)

Daniel-Constantin Mierla miconda at gmail.com
Fri Oct 14 11:21:04 CEST 2022


Based on your parameters, it seems that acc should send cdrs also to
syslog. I think I identified an issue on that code and pushed a fix, can
you test with latest master git branch?

Cheers,
Daniel

On 14.10.22 10:25, Daniel-Constantin Mierla wrote:
>
> OK. Can you run the tests for a while and then execute:
>
> kamctl rpc corex.pkg_summary idx 1
>
> The value for idx should be the kamailio process expected to handle
> sip traffic. If it is mostly udp and the first socket is the
> corresponding udp socket, then the value 1, like above, is ok. If it
> is tcp/tls or you have different listen parameters on udp, see the
> processes index with:
>
> kamctl ps
>
> It should not be required to wait till you get out of memory errors,
> but be sure you run it long enough to have many accounting records
> written by the process that is going to print the pkg summary. You can
> eventually set the children to 1 or 2, to "force" traffic via a
> smaller group of processes.
>
> Cheers,
> Daniel
>
> On 14.10.22 10:12, mayamatakeshi wrote:
>> Hi,
>> I am using acc for CDR generation. Here is the module configuration
>> I'm using:
>>
>> modparam("acc", "db_url",
>> "mysql://kamailio:kamailiorw@localhost/kamailio")
>> modparam("acc", "db_flag", 1)
>> modparam("acc", "db_missed_flag", 2)
>> modparam("acc", "failed_transaction_flag", 3)
>> modparam("acc", "cdr_enable", 1)
>> modparam("acc", "cdrs_table", "cdr")
>> modparam("acc", "cdr_extra",
>> "callid=$ci;caller_domain=$dlg_var(caller_domain);callee_domain=$dlg_var(callee_domain);caller_username=$dlg_var(caller_username);callee_username=$dlg_var(callee_username);calling_number=$dlg_var(calling_number);destination=$dlg_var(destination);anonymous=$dlg_var(anonymous);forwarding=$dlg_var(forwarding);tracing=$dlg_var(tracing);relay=$dlg_var(relay);sip_code=$dlg_var(sip_code);status_code=$dlg_var(status_code);start_time=$dlg_var(start_time)")
>> modparam("acc", "cdr_start_on_confirmed", 1)
>> modparam("acc", "cdr_start_id", "answer_time")
>> modparam("acc", "log_level", 9)
>> modparam("acc", "log_facility", "LOG_LOCAL0")
>> modparam("acc", "log_flag", 10)
>> modparam("acc", "cdr_facility", "LOG_LOCAL0")
>> modparam("acc", "cdr_log_enable", 1)
>>
>>
>> On Fri, Oct 14, 2022 at 3:57 PM Daniel-Constantin Mierla
>> <miconda at gmail.com> wrote:
>>
>>     Hello,
>>
>>     are you using accounting to generate CDRs with dialog module
>>     (records in acc_cdrs table)? Or only for getting the event
>>     records in the acc table?
>>
>>     Cheers,
>>     Daniel
>>
>>     On 13.10.22 23:19, mayamatakeshi wrote:
>>>
>>>
>>>     On Mon, Oct 3, 2022 at 11:41 AM mayamatakeshi
>>>     <mayamatakeshi at gmail.com> wrote:
>>>
>>>
>>>
>>>         On Mon, Sep 26, 2022 at 8:32 PM Daniel-Constantin Mierla
>>>         <miconda at gmail.com> wrote:
>>>
>>>             Hello,
>>>
>>>             as I am not a user of dialog variables, I am turning to
>>>             community to ask
>>>             for help testing the current master branch with
>>>             configurations that make
>>>             use of dialog variables and acc dialog-based cdr generation.
>>>
>>>             With a few reports of issues related to dialog modules
>>>             and unexpected
>>>             crashes, I looked over the code and noticed that the
>>>             access of the value
>>>             for dialog variables was not protected, making them
>>>             vulnerable of
>>>             invalid memory access in case of the variable was
>>>             updated by another
>>>             process or dialog was terminated.
>>>
>>>             I introduced a couple of new functions to try to cover
>>>             different use
>>>             cases of getting the dlg variable values, dialog
>>>             management code was not
>>>             affected, but given that these commits need to be
>>>             backported to stable
>>>             branch (5.6), I want to get proper feedback from
>>>             community that things
>>>             work fine.
>>>
>>>             A previous attempt of a simpler fix was not enough,
>>>             having side effects
>>>             to acc module for dialog-based cdr generation, because
>>>             it was keeping
>>>             referenced to many dlg variables at the same time.
>>>
>>>             In short, it would be appreciated any feedback on
>>>             testing dialog and acc
>>>             with dialog-based cdr generation using git master branch.
>>>
>>>
>>>         I have started 4 load test environments today with latest
>>>         commit 6f400a8074fe60916867596431ca26dff00435d1.
>>>         I usually leave a commit load test running for 2 months
>>>         before consider it ready for production release.
>>>         I will report any crash/problem.
>>>
>>>
>>>     After a few hours of load test, all 4 load test environments
>>>     start to log memory allocation problems:
>>>
>>>     [root at lab002107-flip-server ~]$ grep memory
>>>     /var/log/kamailio/kamailio.log |head
>>>     2022-10-13T01:36:10.429809+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     rtpengine [rtpengine.c:2721]: rtpp_function_call(): out of
>>>     memory - bencode failed
>>>     2022-10-13T01:36:12.923609+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     rtpengine [rtpengine.c:2721]: rtpp_function_call(): out of
>>>     memory - bencode failed
>>>     2022-10-13T01:36:12.961677+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     acc [acc_extra.c:234]: extra2strar(): could not allocate private
>>>     memory from pkg pool
>>>     2022-10-13T01:36:14.983281+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     rtpengine [rtpengine.c:2721]: rtpp_function_call(): out of
>>>     memory - bencode failed
>>>     2022-10-13T01:36:14.983537+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     acc [acc_extra.c:234]: extra2strar(): could not allocate private
>>>     memory from pkg pool
>>>     2022-10-13T01:36:14.983665+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     acc [acc_extra.c:234]: extra2strar(): could not allocate private
>>>     memory from pkg pool
>>>     2022-10-13T01:36:20.861558+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     rtpengine [rtpengine.c:2721]: rtpp_function_call(): out of
>>>     memory - bencode failed
>>>     2022-10-13T01:36:20.864388+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     acc [acc_extra.c:234]: extra2strar(): could not allocate private
>>>     memory from pkg pool
>>>     2022-10-13T01:36:20.878469+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     acc [acc_extra.c:234]: extra2strar(): could not allocate private
>>>     memory from pkg pool
>>>     2022-10-13T01:36:23.174159+09:00 lab002107-flip-server
>>>     /usr/local/src/git/kamailio-master/src/kamailio[3286370]: ERROR:
>>>     rtpengine [rtpengine.c:2721]: rtpp_function_call(): out of
>>>     memory - bencode failed 
>>>
>>>
>>>     I reverted 2 of the load test envs to previous kamailio 5.6
>>>     commit 61e86a1f502388ffd4dce6e52811ba640337c813 and restarted
>>>     the load tests, then again, kamailio master commit
>>>     6f400a8074fe60916867596431ca26dff00435d1 started to write the
>>>     above logs but this doesn't happen with 5.6.
>>>
>>>
>>>
>>     -- 
>>     Daniel-Constantin Mierla -- www.asipto.com <http://www.asipto.com>
>>     www.twitter.com/miconda <http://www.twitter.com/miconda> -- www.linkedin.com/in/miconda <http://www.linkedin.com/in/miconda>
>>     Kamailio Advanced Training - Online
>>       Nov 7-10, 2022 (Europe Timezone)
>>       * https://www.asipto.com/sw/kamailio-advanced-training-online/
>>
> -- 
> Daniel-Constantin Mierla -- www.asipto.com
> www.twitter.com/miconda -- www.linkedin.com/in/miconda
> Kamailio Advanced Training - Online
>   Nov 7-10, 2022 (Europe Timezone)
>   * https://www.asipto.com/sw/kamailio-advanced-training-online/

-- 
Daniel-Constantin Mierla -- www.asipto.com
www.twitter.com/miconda -- www.linkedin.com/in/miconda
Kamailio Advanced Training - Online
  Nov 7-10, 2022 (Europe Timezone)
  * https://www.asipto.com/sw/kamailio-advanced-training-online/
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.kamailio.org/pipermail/sr-dev/attachments/20221014/188f1ab4/attachment-0001.htm>


More information about the sr-dev mailing list