ВидеоКонф(ВКС)  ::   FAQ  ::   Поиск  ::   Регистрация  ::   Вход

При входящем звонке выбирается не тот endpoint

Новичком считается только что прочитавший «Астериск - будущее телефонии»
http://asterisk.ru/knowledgebase/books
и пытающийся сделать большее

Модераторы: april22, Zavr2008

При входящем звонке выбирается не тот endpoint

Сообщение Firzen475 » 04 июн 2021, 21:09

Приветствую.
Удалось настроить входящие и исходящие звонки. Но при входящем звонке на номер 8(ххх)ххх-хх-46, при выполнении контекста, по какой-то причине Asterisk выбирает endpoint от номера 8(ххх)ххх-хх-47 и занимает его. Из-за этого нет возможности правильно определить, какая линия свободна для исходящего вызова. endpoint номера 8(ххх)ххх-хх-46 определяется как свободный, хотя сама линия занята.
Если удалить второй trunk (8(ххх)ххх-хх-47), то выбирается нужный endpoint.

pjsip.conf
Код: выделить все
[udp-transport]
type=transport
protocol=udp
bind=XXX.XXX.XXX.XXX
local_net=XXX.XXX.XXX.0/24
local_net=XXX.XXX.XXX.0/24
local_net=127.0.0.1/32

;—TRUNK DESCRIPTION—;

;—TRUNK 1—;

[trunk1_reg]
type=registration
transport=udp-transport
outbound_auth=trunk1_auth
server_uri=sip:voip.domru.ru:5060
client_uri=sip:7XXXXXXXX46@voip.domru.ru:5060
contact_user=7XXXXXXXX46

[trunk1_auth]
type=auth
auth_type=userpass
password=password
username=7XXXXXXXX46

[trunk1_aor]
type=aor
contact=sip:7XXXXXXXX46@voip.domru.ru:5060

[trunk1_ep]
type=endpoint
transport=udp-transport
context=incoming
disallow=all
allow=alaw
callerid = "7XXXXXXXX46"<7XXXXXXXX46>
from_user = 7XXXXXXXX46
language = ru
outbound_auth=trunk1_auth
aors=trunk1_aor

[trunk1_id]
type=identify
endpoint=trunk1_ep
match=188.234.136.49

;—TRUNK 2—;

[trunk2_reg]
type=registration
transport=udp-transport
outbound_auth=trunk2_auth
server_uri=sip:voip.domru.ru:5060
client_uri=sip:7XXXXXXXX47@voip.domru.ru:5060
contact_user=7XXXXXXXX47

[trunk2_auth]
type=auth
auth_type=userpass
password=password
username=7XXXXXXXX47

[trunk2_aor]
type=aor
contact=sip:7XXXXXXXX47@voip.domru.ru:5060

[trunk2_ep]
type=endpoint
transport=udp-transport
context=incoming
disallow=all
allow=alaw
callerid = "7XXXXXXXX47"<7XXXXXXXX47>
from_user = 7XXXXXXXX47
language = ru
outbound_auth=trunk2_auth
aors=trunk2_aor

[trunk2_id]
type=identify
endpoint=trunk2_ep
match=188.234.136.49


extensions.conf
Код: выделить все
[incoming]
exten => 7XXXXXXXX46,1,Answer()
exten => 7XXXXXXXX46,2,Background(basic-pbx-ivr-main)
exten => 7XXXXXXXX46,3,WaitExten(5)
exten => 7XXXXXXXX46,4,Answer
exten => 7XXXXXXXX46,5,Background(/var/lib/asterisk/sounds/ru/beep)
exten => 7XXXXXXXX46,6,Queue(ring107)
exten => 7XXXXXXXX46,7,Hangup()

exten => 7XXXXXXXX47,1,Answer()
exten => 7XXXXXXXX47,2,Background(basic-pbx-ivr-main)
exten => 7XXXXXXXX47,3,WaitExten(5)
exten => 7XXXXXXXX47,4,Answer
exten => 7XXXXXXXX47,5,Background(/var/lib/asterisk/sounds/ru/beep)
exten => 7XXXXXXXX47,6,Queue(ring111)
exten => 7XXXXXXXX47,7,Hangup()
include => selected

...

[outgoing]
exten => _8xxxxxxxxxx,1,GoTo(7${EXTEN:1},1)
exten =>_7XXXXXXXXXX,1,ChanIsAvail(PJSIP/${EXTEN}@trunk1_ep&PJSIP/${EXTEN}@trunk2_ep)
exten =>_7XXXXXXXXXX,2,NoOp(${AVAILCHAN})
exten =>_7XXXXXXXXXX,3,NoOp(${AVAILORIGCHAN})
exten =>_7XXXXXXXXXX,4,NoOp(${AVAILSTATUS})
exten =>_7XXXXXXXXXX,5,Dial(${AVAILORIGCHAN})
exten =>_7XXXXXXXXXX,6,Hangup()


console
Код: выделить все
Connected to Asterisk 18.4.0 currently running on asterisk (pid = 12235)
    -- Executing [7XXXXXXXX46@incoming:1] Answer("trunk2_ep-0000000a", "") in new stack
       > 0x7f3c00335d60 -- Strict RTP learning after remote address set to: 188.234.136.49:23586
    -- Executing [7XXXXXXXX46@incoming:2] BackGround("PJSIP/trunk2_ep-0000000a", "basic-pbx-ivr-main") in new stack
    -- <PJSIP/trunk2_ep-0000000a> Playing 'basic-pbx-ivr-main.alaw' (language 'ru')
       > 0x7f3c00335d60 -- Strict RTP switching to RTP target address 188.234.136.49:23586 as source
       > 0x7f3c00335d60 -- Strict RTP learning complete - Locking on source address 188.234.136.49:23586


Особое внимание на:
Executing [7XXXXXXXX46@incoming:1] Answer("trunk2_ep-0000000a", "") in new stack
и
Executing [7XXXXXXXX46@incoming:2] BackGround("PJSIP/trunk2_ep-0000000a", "basic-pbx-ivr-main") in new stack

Прошу помощи в понимании причин этого феномена.
Firzen475
 
Сообщений: 2
Зарегистрирован: 04 июн 2021, 20:10

Re: При входящем звонке выбирается не тот endpoint

Сообщение ded » 07 июн 2021, 12:05

С точки зрения IP_адресации - 188.234.136.49:5060 - это один и тот же транк, как бы вы не старались его представить в виде двух.

У вас [trunk1_id] и [trunk2_id] имеют один и тот же
match=188.234.136.49
так что Астериск матчит (ищет совпадение) только по этому параметру, и не видит разницы между trunk1_id и trunk2_id.
Если не хотите исследовать квантовую запутанность pjsip, поднимите всё на chan_sip и живите долго и счастливо.
ded
 
Сообщений: 15805
Зарегистрирован: 26 авг 2010, 19:00

Re: При входящем звонке выбирается не тот endpoint

Сообщение Zavr2008 » 07 июн 2021, 12:09

На chan_sip тоже есть такое, как решение - просто запускать в один и тот же контекст и далее разруливать уже по DID входящие.
Российские шлюзы E1 Alvis-GW. Модернизация УПАТС с E1, Установка FreePBX, Системы антифрод "в разрыв" потоков E1 PRI / SS#7 ISUP.
Аватар пользователя
Zavr2008
 
Сообщений: 2162
Зарегистрирован: 27 янв 2011, 01:35

Re: При входящем звонке выбирается не тот endpoint

Сообщение ded » 07 июн 2021, 13:58

Он так и пытался - всё разруливать по DID в одном контексте [incoming]
ded
 
Сообщений: 15805
Зарегистрирован: 26 авг 2010, 19:00

Re: При входящем звонке выбирается не тот endpoint

Сообщение Firzen475 » 08 июн 2021, 12:43

Спасибо ded! Ваш ответ дал мне направление для поисков и мне удалось решить проблему.
Действительно по полю match происходит сопоставление endpointов. Я выяснил что начиная с версии 15.3.0 модуль res_pjsip_endpoint_identifier_ip.so позволяет читать заголовки с помощью опции match_header
Я внес следующие изменения в файл pjsip.conf
Код: выделить все
[global]
...
endpoint_identifier_order = header,ip,auth_username,username,anonymous
...

[trunk1_id]
type=identify
endpoint=trunk1_ep
match_header=To: <sip:7ХХХХХХХХХ46@[Ваш внешний ip]\;user=phone\;realip=[Ваш внешний ip]>

[trunk2_id]
type=identify
endpoint=trunk2_ep
match_header=To: <sip:7ХХХХХХХХХ47@[Ваш внешний ip]\;user=phone\;realip=[Ваш внешний ip]>


Чтобы понять, какую строку вставлять я воспользовался отладкой. В случае несоответствия там должно быть что-то похожее на:
Код: выделить все
res_pjsip_endpoint_identifier_ip.c:174 header_identify_match_check: SIP message contains header 'To' but value '[Ваша строка match_header]' does not match value ''[Строка которую ожидает модуль]'' for endpoint 'trunk1_ep'


Также нашел похожую проблему на этом форуме, но не смог бы её найти без подсказки что искать.
https://forum.asterisk.ru/viewtopic.php?f=3&t=11719

Спасибо за помощь!
Firzen475
 
Сообщений: 2
Зарегистрирован: 04 июн 2021, 20:10


Вернуться в Вопросы новичков

Кто сейчас на форуме

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 44

© 2008 — 2024 Asterisk.ru
Digium, Asterisk and AsteriskNOW are registered trademarks of Digium, Inc.
Design and development by PostMet-Netzwerk GmbH