Я пытаюсь настроить облачный сервер Asterisk, который находится за NAT, с примером hello-world. У меня проблемы с NAT. IP-адрес, который Asterisk передает клиенту через SDP, является его локальным адресом за NAT, а не внешним адресом.
Я попытался установить externip
ценность в sip.conf
, но это, похоже, не действует.
[general]
externip=xxx.yyy.zzz.vvv
nat=yes
tcpenable=yes
SDP, полученный на клиенте, не согласуется с сервером externip
настройка:
v=0
o=root 291445984 291445984 IN IP4 172.31.46.110
s=Asterisk PBX 11.7.0~dfsg-1ubuntu1
c=IN IP4 172.31.46.110
t=0 0
m=audio 10078 RTP/AVP 0 101
a=rtpmap:0 PCMU/8000
a=rtpmap:101 telephone-event/8000
a=fmtp:101 0-16
a=ptime:20
a=sendrecv
m=video 0 RTP/AVP 96
Я ожидаю, что адрес в SDP будет соответствовать адресу, указанному в externip
поле. Я пробовал как фактический IP-адрес, так и имя сервера, которое правильно разрешается в IP-адрес через DNS.
Я устанавливаю externip
значение неверно? Или есть другой параметр, который требуется, чтобы Asterisk объявлял свой внешний IP-адрес?
Вы забыли установить localnet
. Файл конфигурации предупредил вас, что вы должны установить это значение равным netblock вашей локальной сети.
;----------------------------------------- NAT SUPPORT ------------------------
;
; WARNING: SIP operation behind a NAT is tricky and you really need
; to read and understand well the following section.
;
; When Asterisk is behind a NAT device, the "local" address (and port) that
; a socket is bound to has different values when seen from the inside or
; from the outside of the NATted network. Unfortunately this address must
; be communicated to the outside (e.g. in SIP and SDP messages), and in
; order to determine the correct value Asterisk needs to know:
;
; + whether it is talking to someone "inside" or "outside" of the NATted network.
; This is configured by assigning the "localnet" parameter with a list
; of network addresses that are considered "inside" of the NATted network.
; IF LOCALNET IS NOT SET, THE EXTERNAL ADDRESS WILL NOT BE SET CORRECTLY.
; Multiple entries are allowed, e.g. a reasonable set is the following:
;
; localnet=192.168.0.0/255.255.0.0 ; RFC 1918 addresses
; localnet=10.0.0.0/255.0.0.0 ; Also RFC1918
; localnet=172.16.0.0/12 ; Another RFC1918 with CIDR notation
; localnet=169.254.0.0/255.255.0.0 ; Zero conf local network
На самом деле обычно нормально просто раскомментировать все четыре примера. localnet
директивы и прекратить работу.
(И вы должны очень громко жаловаться на отсутствие поддержки IPv6 у вашего поставщика услуг ...)