[asterisk-bugs] [JIRA] (ASTERISK-27251) chan_sip doesn't honour rtptimeout setting
Ian Gilmour (JIRA)
noreply at issues.asterisk.org
Mon Sep 11 10:09:07 CDT 2017
[ https://issues.asterisk.org/jira/browse/ASTERISK-27251?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=238641#comment-238641 ]
Ian Gilmour edited comment on ASTERISK-27251 at 9/11/17 10:07 AM:
------------------------------------------------------------------
Note, I can also reregister the same chan_sip SIP client (Jitsi) with Asterisk, rejoin the same conf call, and again kill the sip client's network connection, and I can do this multiple times. This results in the same user appearing in the conf call multiple times. Every time I do this it adds another outgoing Asterisk media stream, that continues to be sent packets indefinitely, with (potentially) nothing at the other end to receive it.
{noformat}
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 0f2e4ed2355 00:00:22 0000000901 0000000000 ( 0.00%) 0.0000 0000000822 0000000000 ( 0.00%) 0.0060
10.10.0.19 daa1c4bb415 00:51:44 0000001761 0000000000 ( 0.00%) 0.0000 0000000154K 0000000000 ( 0.00%) 0.0063
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:09 0000003297 0000000000 ( 0.00%) 0.0000 0000003076 0000000003 ( 0.10%) 0.0062
10.10.0.19 0f2e4ed2355 00:21:52 0000034224 0000000000 ( 0.00%) 0.0000 0000064726 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:14 0000001761 0000000000 ( 0.00%) 0.0000 0000000217K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:12 0000002196 0000000000 ( 0.00%) 0.0000 0000008971 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:11 0000003413 0000000000 ( 0.00%) 0.0000 0000003192 0000000003 ( 0.09%) 0.0063
10.10.0.19 0f2e4ed2355 00:21:54 0000034224 0000000000 ( 0.00%) 0.0000 0000064842 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:17 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:15 0000002196 0000000000 ( 0.00%) 0.0000 0000009087 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:13 0000003517 0000000000 ( 0.00%) 0.0000 0000003296 0000000003 ( 0.09%) 0.0057
10.10.0.19 0f2e4ed2355 00:21:56 0000034224 0000000000 ( 0.00%) 0.0000 0000064946 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:19 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:17 0000002196 0000000000 ( 0.00%) 0.0000 0000009191 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:16 0000003629 0000000000 ( 0.00%) 0.0000 0000003408 0000000003 ( 0.09%) 0.0066
10.10.0.19 0f2e4ed2355 00:21:58 0000034224 0000000000 ( 0.00%) 0.0000 0000065058 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:21 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:19 0000002196 0000000000 ( 0.00%) 0.0000 0000009303 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:17 0000003687 0000000000 ( 0.00%) 0.0000 0000003466 0000000003 ( 0.09%) 0.0061
10.10.0.19 0f2e4ed2355 00:22:00 0000034224 0000000000 ( 0.00%) 0.0000 0000065116 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:22 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:20 0000002196 0000000000 ( 0.00%) 0.0000 0000009361 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:18 0000003754 0000000000 ( 0.00%) 0.0000 0000003533 0000000003 ( 0.08%) 0.0060
10.10.0.19 0f2e4ed2355 00:22:01 0000034224 0000000000 ( 0.00%) 0.0000 0000065183 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:23 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:21 0000002196 0000000000 ( 0.00%) 0.0000 0000009428 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> conf
confbridge config
*CLI> confbridge
kick list lock mute record show unlock unmute
*CLI> confbridge list 1234
Channel Flags User Profile Bridge Profile Menu CallerID
============================== ====== ================ ================ ================ ================
SIP/1006-00000000 ME USER conferences admin_menu 1006
SIP/1006-00000001 ME USER conferences user_menu 1006
SIP/1006-00000002 ME USER conferences user_menu 1006
SIP/1006-00000003 ME USER conferences user_menu 1006
*CLI>
{noformat}
This simulates a SIP client at the end of a dodgy network connection - so it seems reasonable to expect Asterisk to handle it slightly more gracefully.
was (Author: tuxian):
Note, I can also reregister the same chan_sip SIP client (Jitsi) with Asterisk, rejoin the same conf call, and again kill the sip client's network connection, and I can do this multiple times. This results in the same user appearing in the conf call multiple times. Every time I do this it adds another outgoing Asterisk media stream, that continues to be sent packets indefinitely, with (potentially) nothing at the other end to receive it.
{noformat}
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 0f2e4ed2355 00:00:22 0000000901 0000000000 ( 0.00%) 0.0000 0000000822 0000000000 ( 0.00%) 0.0060
10.10.0.19 daa1c4bb415 00:51:44 0000001761 0000000000 ( 0.00%) 0.0000 0000000154K 0000000000 ( 0.00%) 0.0063
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:09 0000003297 0000000000 ( 0.00%) 0.0000 0000003076 0000000003 ( 0.10%) 0.0062
10.10.0.19 0f2e4ed2355 00:21:52 0000034224 0000000000 ( 0.00%) 0.0000 0000064726 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:14 0000001761 0000000000 ( 0.00%) 0.0000 0000000217K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:12 0000002196 0000000000 ( 0.00%) 0.0000 0000008971 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:11 0000003413 0000000000 ( 0.00%) 0.0000 0000003192 0000000003 ( 0.09%) 0.0063
10.10.0.19 0f2e4ed2355 00:21:54 0000034224 0000000000 ( 0.00%) 0.0000 0000064842 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:17 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:15 0000002196 0000000000 ( 0.00%) 0.0000 0000009087 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:13 0000003517 0000000000 ( 0.00%) 0.0000 0000003296 0000000003 ( 0.09%) 0.0057
10.10.0.19 0f2e4ed2355 00:21:56 0000034224 0000000000 ( 0.00%) 0.0000 0000064946 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:19 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:17 0000002196 0000000000 ( 0.00%) 0.0000 0000009191 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:16 0000003629 0000000000 ( 0.00%) 0.0000 0000003408 0000000003 ( 0.09%) 0.0066
10.10.0.19 0f2e4ed2355 00:21:58 0000034224 0000000000 ( 0.00%) 0.0000 0000065058 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:21 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:19 0000002196 0000000000 ( 0.00%) 0.0000 0000009303 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:17 0000003687 0000000000 ( 0.00%) 0.0000 0000003466 0000000003 ( 0.09%) 0.0061
10.10.0.19 0f2e4ed2355 00:22:00 0000034224 0000000000 ( 0.00%) 0.0000 0000065116 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:22 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:20 0000002196 0000000000 ( 0.00%) 0.0000 0000009361 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> sip show channelstats
Peer Call ID Duration Recv: Pack Lost ( %) Jitter Send: Pack Lost ( %) Jitter
10.10.0.19 ac65cff28ff 00:01:18 0000003754 0000000000 ( 0.00%) 0.0000 0000003533 0000000003 ( 0.08%) 0.0060
10.10.0.19 0f2e4ed2355 00:22:01 0000034224 0000000000 ( 0.00%) 0.0000 0000065183 0000000000 ( 0.00%) 0.0063
10.10.0.19 daa1c4bb415 01:13:23 0000001761 0000000000 ( 0.00%) 0.0000 0000000218K 0000000000 ( 0.00%) 0.0063
10.10.0.19 1e1f8c48ab4 00:03:21 0000002196 0000000000 ( 0.00%) 0.0000 0000009428 0000000000 ( 0.00%) 0.0060
4 active SIP channels
*CLI> conf
confbridge config
*CLI> confbridge
kick list lock mute record show unlock unmute
*CLI> confbridge list 1234
Channel Flags User Profile Bridge Profile Menu CallerID
============================== ====== ================ ================ ================ ================
SIP/1006-00000000 ME USER conferences admin_menu 1006
SIP/1006-00000001 ME USER conferences user_menu 1006
SIP/1006-00000002 ME USER conferences user_menu 1006
SIP/1006-00000003 ME USER conferences user_menu 1006
*CLI>
{noformat}
This simulates a SIP client at the end of a dodgy network connection - so it seems reasonable to expect Asterisk to handle.
> chan_sip doesn't honour rtptimeout setting
> ------------------------------------------
>
> Key: ASTERISK-27251
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-27251
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: Channels/chan_sip/General
> Affects Versions: 13.17.1
> Environment: Ubuntu 16.04 (64-bit)
> Reporter: Ian Gilmour
> Assignee: Unassigned
> Attachments: cli.tgz
>
>
> I have Asterisk running in the cloud with sip.conf configured with:
> {noformat}
> rtptimeout=60
> rtpholdtimeout=300
> rtpkeepalive=20
> {noformat}
> I have a confbridge managed conference room, configured to play MOH if there is only 1 participant.
> I have a SIP client (Jitsi) configured to use TLS+SRTP. It registers with Asterisk on a chan_sip managed IP address + port.
> The SIP client is behind a NAT.
> If the SIP client enters the conference room MOH plays as expected. If I then disconnect the SIP client from the network (so it doesn't deregister, or issue a SIP BYE) I see Asterisk sending media (MOH) to the SIP client's orginal IP address and port indefinitely (>24hours+) and the CLI shows the user as present in the conf call. Media output only terminates if I kick the user manually out of the conf call via the CLI.
> Once the SIP client is disconnected from the network wireshark shows ICMP Destination unreachable messages being returned in response to each Asterisk (MOH) outgoing media packet.
> n.b. I see similar behaviour if I run both Asterisk and client locally. i.e. no NAT.
> The bug seems to be related to ASTERISK-26523.
> Reverting the ASTERISK-26523 change so that it only updates the lastrtprx if the frame isn't AST_FRAME_NULL gives me a chan_sip that honours the sip.conf rtptimeout.
--
This message was sent by Atlassian JIRA
(v6.2#6252)
More information about the asterisk-bugs
mailing list