[asterisk-bugs] [JIRA] (ASTERISK-15824) Create CDR queue so records are not lost when connectivity is lost

Matt Jordan (JIRA) noreply at issues.asterisk.org
Thu May 16 10:50:48 CDT 2013


    [ https://issues.asterisk.org/jira/browse/ASTERISK-15824?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=206488#comment-206488 ] 

Matt Jordan commented on ASTERISK-15824:
----------------------------------------

Hm. I had no idea this was still open.

No effort has been done on this particular new feature idea since 2010, i.e., no version of Asterisk contains this feature. Since new features only go into trunk, the earliest version that would support such a feature is Asterisk 12.

While CDRs are being given a lot of attention in Asterisk 12, it is only because of the work going on in the bridging framework. At this time, there is no plan to add or address this new feature, and, given the limited time remaining before Asterisk 12 is branched and new features are frozen, it will not be added to that work.

New features are actually not kept open in the Issue tracker unless they are being actively worked or there is a patch available and attached to the issue. In this case, none of those things are true - so I'm actually going to close this out as "Suspended" so that it doesn't cause any further confusion.
                
> Create CDR queue so records are not lost when connectivity is lost
> ------------------------------------------------------------------
>
>                 Key: ASTERISK-15824
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-15824
>             Project: Asterisk
>          Issue Type: New Feature
>          Components: CDR/NewFeature
>            Reporter: Leif Madsen
>
> The current CDR implementation in Asterisk does nothing to ensure that every CDR record is successfully logged to configured logging destinations.  A single attempt is made to log a record.  If for some reason it fails, such as connectivity to a database being temporarily disrupted, then the records are lost.  Obviously, this is very bad in many cases where these records are used for things like billing.
> The primary purpose behind these changes is to ensure that every record is successfully logged to every destination that has been configured.  If posting a CDR fails, it will be queued up for a retry later.
> A new method has been added for backends to register callbacks for receiving CDR records.  For CDR modules that allow posting CDRs to multiple destinations, such as multiple DB tables or multiple text files, they now make a registration into the core for every destination.  That way, the success or failure of the attempt to each destination can be tracked.  All backends that need it have been updated to operate this way.
> main/cdr.c has also been updated to use more modern Asterisk APIs.  It has also been updated with various other bits of code cleanup.
> One side effect of these changes is that the code that previously implemented the batch mode has been completely removed, as that code is now deprecated.  The biggest benefit from batch mode was handling CDR posting asynchronously from channel threads.  In this code, that is the only behavior that exists.
> ****** STEPS TO REPRODUCE ******
> I have done some manual testing.  However, before I consider this done, I would like to implement some automated tests, as well as touch on more backends than what I have tested so far.
> I configured cdr_custom to log CDRs to multiple files.  I made calls and verified that records were logged successfully.  I made some modifications on disk such that attempts to log to one file would fail, while the other would continue to succeed.  I made more calls and verified that the CDR queue grew for the specific file that had failures.  I fixed the problem and continued making calls.  I verified that all previously failed CDRs were posted and that both files were in sync with the number of CDRs that they had.
> ****** ADDITIONAL INFORMATION ******
> Branch available at:  http://svn.asterisk.org/svn/asterisk/team/russell/cdr-q/

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.asterisk.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira



More information about the asterisk-bugs mailing list