[asterisk-bugs] [JIRA] (ASTERISK-25797) app_queue: Crash when calling a queue with a member with a forward to an nonexistent extension
Etienne Lessard (JIRA)
noreply at issues.asterisk.org
Wed Feb 17 07:12:33 CST 2016
[ https://issues.asterisk.org/jira/browse/ASTERISK-25797?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=229548#comment-229548 ]
Etienne Lessard edited comment on ASTERISK-25797 at 2/17/16 7:12 AM:
---------------------------------------------------------------------
Note that this is not a "typical" crash where the process receives a SIGSEGV or SIGABRT signal and generates a core dump. The problem is that the asterisk process try to allocate an infinite amount of memory, which leads to an out-of-memory situation. The process terminates because the kernel out-of-memory killer kills it. By default no core dump is generated.
Still, I've generated a core dump by manually issuing a SIGABRT to the process while it was in the "inifite loop, eating all system memory" state (but before reaching an out-of-memory situation). I've attached the corresponding backtrace. (the core dump was generated using a slightly different setup than described in my original comment; the extension called is 1001 and the queue name is "file1").
was (Author: hexanol):
Note that this is not a "typical" crash where the process receives a SIGSEGV or SIGABRT signal and generates a core dump. The problem is that the asterisk process try to allocate an infinite amount of memory, which leads to an out-of-memory situation. The process terminates because the kernel out-of-memory killer kills it. By default no core dump is generated.
Still, I've generated a core dump by manually issuing a SIGABRT to the process while it was in the "inifite loop, eating all system memory" state (but before reaching an out-of-memory situation). I've attached the corresponding backtrace. (the backtrace was generated using a slightly different setup; the extension called is 1001 and the queue name is "file1").
> app_queue: Crash when calling a queue with a member with a forward to an nonexistent extension
> ----------------------------------------------------------------------------------------------
>
> Key: ASTERISK-25797
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-25797
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: Applications/app_queue
> Affects Versions: 13.6.0, 13.7.2
> Environment: Debian 8.3 amd64
> Reporter: Etienne Lessard
> Assignee: Unassigned
> Attachments: AST-25797.backtrace.txt, AST-25797.log
>
>
> Given I have a queue with 1 member: Alice (SIP/alice)
> Given Alice's phone has a forward (SIP native) to the 444 extension, and the 444 extension isn't defined in the dialplan
> When Bob calls the queue
> Then asterisk get stuck in what seems to be an infinite loop, consuming a lot of CPU time, and rapidly consuming (in the matter of seconds) all the available memory in the system, until the kernel OOM killer terminate the process
> In my example, I used the following queues.conf:
> {code}
> [sales]
> strategy = ringall
> member => SIP/alice
> {code}
> And the following extensions.conf:
> {code}
> [default]
> exten = 101,1,NoOp()
> same = n,Queue(sales)
> same = n,Hangup()
> {code}
> When Alice's phone receives a SIP INVITE from asterisk, since it has an unconditional forward enabled, it respond with a "302 Moved Temporarily" with the header "Contact: <sip:444 at 10.34.1.11>".
> I've attached the interesting part of the log.
> Thank you
--
This message was sent by Atlassian JIRA
(v6.2#6252)
More information about the asterisk-bugs
mailing list