[OpenSIPS-Users] Cluster (anycast) adds extra hex 00 in the tail to replicated responses.

Răzvan Crainea razvan at opensips.org
Mon Jan 9 08:24:37 UTC 2023


Hi, Denys!

I've just pushed a fix[1] in the master branch - can you please give it 
a try and let me know if this fixes your setup, so I can backport it 
down to 3.1?

[1] 
https://github.com/OpenSIPS/opensips/commit/81e9b14a16acd284469d8958c57dcece69699a85

Best regards,

Răzvan Crainea
OpenSIPS Core Developer
http://www.opensips-solutions.com

On 1/9/23 10:03, Denys Pozniak wrote:
> Hello!
> 
> Sorry to bring the topic up, but so far I have no idea what the problem 
> is. Or do I need to open an issue on github?
> 
> вт, 3 янв. 2023 г. в 13:58, Denys Pozniak <denys.pozniak at gmail.com 
> <mailto:denys.pozniak at gmail.com>>:
> 
>     Hello!
> 
>     I'm trying to build a classic anycast cluster topology with two
>     OpenSIPS nodes, in which requests are processed by one proxy and
>     responses by another.
>     The client and server are emulated via baresip.
>     But I ran into a problem in that the replicated responses have an
>     extra 00 in the tail of the reply (the original reply from baresip
>     UAS does not have it).
> 
>     ngrep -x:
>     #
>     U 192.168.100.100:5060 <http://192.168.100.100:5060> ->
>     192.168.56.103:37279 <http://192.168.56.103:37279> #5
>        53 49 50 2f 32 2e 30 20    31 38 30 20 52 69 6e 67    SIP/2.0 180
>     Ring
>        69 6e 67 0d 0a 52 65 63    6f 72 64 2d 52 6f 75 74  
>       ing..Record-Rout
>        65 3a 20 3c 73 69 70 3a    31 39 32 2e 31 36 38 2e    e:
>     <sip:192.168.
>        31 30 30 2e 31 30 30 3b    6c 72 3e 0d 0a 56 69 61  
>       100.100;lr>..Via
>        3a 20 53 49 50 2f 32 2e    30 2f 55 44 50 20 31 39    :
>     SIP/2.0/UDP 19
>        32 2e 31 36 38 2e 35 36    2e 31 30 33 3a 33 37 32
>     2.168.56.103:372 <http://2.168.56.103:372>
>        37 39 3b 72 65 63 65 69    76 65 64 3d 31 39 32 2e  
>       79;received=192.
>        31 36 38 2e 35 36 2e 31    30 33 3b 62 72 61 6e 63  
>       168.56.103;branc
>        68 3d 7a 39 68 47 34 62    4b 62 65 63 38 65 38 66  
>       h=z9hG4bKbec8e8f
>        30 32 36 62 65 39 31 34    61 3b 72 70 6f 72 74 3d  
>       026be914a;rport=
>        33 37 32 37 39 0d 0a 54    6f 3a 20 3c 73 69 70 3a    37279..To:
>     <sip:
>        31 30 30 40 31 39 32 2e    31 36 38 2e 31 30 30 2e
>     100 at 192.168.100. <mailto:100 at 192.168.100.>
>        31 30 30 3b 74 72 61 6e    73 70 6f 72 74 3d 75 64  
>       100;transport=ud
>        70 3e 3b 74 61 67 3d 32    37 65 33 63 32 31 38 65  
>       p>;tag=27e3c218e
>        30 65 61 31 32 30 64 0d    0a 46 72 6f 6d 3a 20 3c  
>       0ea120d..From: <
>        73 69 70 3a 32 30 30 40    31 39 32 2e 31 36 38 2e  
>       sip:200 at 192.168.
>        31 30 30 2e 31 30 30 3a    35 30 36 30 3e 3b 74 61  
>       100.100:5060>;ta
>        67 3d 35 36 38 35 66 33    38 39 61 39 37 66 65 31  
>       g=5685f389a97fe1
>        30 32 0d 0a 43 61 6c 6c    2d 49 44 3a 20 31 32 34  
>       02..Call-ID: 124
>        39 37 61 63 37 36 65 38    30 34 66 35 36 0d 0a 43  
>       97ac76e804f56..C
>        53 65 71 3a 20 36 33 37    30 37 20 49 4e 56 49 54    Seq: 63707
>     INVIT
>        45 0d 0a 53 65 72 76 65    72 3a 20 62 61 72 65 73    E..Server:
>     bares
>        69 70 20 76 32 2e 31 30    2e 30 20 28 78 38 36 5f    ip v2.10.0
>     (x86_
>        36 34 2f 4c 69 6e 75 78    29 0d 0a 43 6f 6e 74 61  
>       64/Linux)..Conta
>        63 74 3a 20 3c 73 69 70    3a 31 30 30 2d 30 78 63    ct:
>     <sip:100-0xc
>        62 63 31 39 30 40 31 39    32 2e 31 36 38 2e 35 36  
>       bc190 at 192.168.56
>        2e 31 30 36 3a 35 30 38    30 3e 0d 0a 41 6c 6c 6f  
>       .106:5080>..Allo
>        77 3a 20 49 4e 56 49 54    45 2c 41 43 4b 2c 42 59    w:
>     INVITE,ACK,BY
>        45 2c 43 41 4e 43 45 4c    2c 4f 50 54 49 4f 4e 53  
>       E,CANCEL,OPTIONS
>        2c 4e 4f 54 49 46 59 2c    53 55 42 53 43 52 49 42  
>       ,NOTIFY,SUBSCRIB
>        45 2c 49 4e 46 4f 2c 4d    45 53 53 41 47 45 2c 55  
>       E,INFO,MESSAGE,U
>        50 44 41 54 45 2c 52 45    46 45 52 0d 0a 43 6f 6e  
>       PDATE,REFER..Con
>        74 65 6e 74 2d 4c 65 6e    67 74 68 3a 20 30 0d 0a  
>       tent-Length: 0..
>        0d 0a 00                                              ...
>     #
> 
>     So it throws a Baresip error:
>     call: SIP Progress: 100 Trying-2 (/)
>     call: SIP Progress: 100 Giving it a try (/)
>     call: SIP Progress: 180 Ringing (/)
>     call: could not decode SDP answer: Bad message [74]
> 
>     192.168.56.103 - baresip UAC
>     192.168.56.106 - baresip UAS
>     192.168.100.100 - anycast OpenSIPS
> 
>     opensips.cfg (node2):
>     ...
>     socket = udp:192.168.100.100 anycast
>     socket= bin:192.168.56.105:5566 <http://192.168.56.105:5566>
>     ...
>     modparam ("tm", "tm_replication_cluster", 1)
>     modparam("clusterer", "db_mode", 0)
>     modparam("clusterer", "my_node_id", 2)
>     modparam("clusterer", "my_node_info", "cluster_id=1,
>     url=bin:192.168.56.105:5566 <http://192.168.56.105:5566>")
>     modparam("clusterer", "neighbor_node_info",
>     "cluster_id=1,node_id=1,url=bin:192.168.56.104:5566
>     <http://192.168.56.104:5566>")
>     modparam("clusterer", "sharing_tag", "vip1/2=active")
>     ...
>     ####### Routing Logic ########
> 
>     route{
> 
>              if ( !mf_process_maxfwd_header(10) ) {
>                      send_reply(483,"Too Many Hops");
>                      exit;
>              }
> 
>              sl_send_reply(100, "Trying-2");
> 
>              if (has_totag()) {
> 
>                      if ( !loose_route() && !t_check_trans() ) {
>                              if ( is_method("ACK") ) {
>                                      t_anycast_replicate();
>                                      exit;
>                              }
>                      }
> 
>                      t_relay();
>                      exit;
>              }
> 
>              if (is_method("CANCEL")) {
>                      if (t_check_trans()) {
>                              t_relay();
> 
>                      } else {
>                              t_anycast_replicate();
>                      }
> 
>                      exit;
>              }
> 
>              t_check_trans();
> 
>              if (!is_method("REGISTER|MESSAGE")) {
>                      record_route();
>              }
> 
>              if ( is_method("INVITE") && $si!="5080" ) {
>                      $du = "sip:192.168.56.106:5080
>     <http://192.168.56.106:5080>";
>              }
> 
>              t_relay();
>              exit;
> 
>     }
> 
>     [root at localhost opensips]# opensips -V
>     version: opensips 3.3.2 (x86_64/linux)
>     flags: STATS: On, DISABLE_NAGLE, USE_MCAST, SHM_MMAP, PKG_MALLOC,
>     Q_MALLOC, F_MALLOC, HP_MALLOC, DBG_MALLOC, FAST_LOCK-ADAPTIVE_WAIT
>     ADAPTIVE_WAIT_LOOPS=1024, MAX_RECV_BUFFER_SIZE 262144, MAX_LISTEN
>     16, MAX_URI_SIZE 1024, BUF_SIZE 65535
>     poll method support: poll, epoll, sigio_rt, select.
>     main.c compiled on 16:12:02 Oct 19 2022 with gcc 4.8.5
> 
> 
>     -- 
> 
>     BR,
>     Denys Pozniak
> 
> 
> 
> 
> -- 
> 
> BR,
> Denys Pozniak
> 
> 
> 
> _______________________________________________
> Users mailing list
> Users at lists.opensips.org
> http://lists.opensips.org/cgi-bin/mailman/listinfo/users



More information about the Users mailing list