[Users] TCP socket problem

Klaus Darilion klaus.mailinglists at pernau.at
Tue Aug 16 18:29:35 CEST 2005


My server configuration:
# ifconfig
eth0      Link encap:Ethernet  HWaddr 00:0B:DB:90:FA:3F
           inet addr:x.x.32.80  Bcast:x.x.32.127

eth0:3    Link encap:Ethernet  HWaddr 00:0B:DB:90:FA:3F
           inet addr:x.x.32.83  Bcast:x.x.32.127

eth0 .80 is the default interface, openser listens on .83
This is done by putting
   listen=x.x.32.83:5060
into openser.cfg

openser binds to .83, verified by # netstat -anp|grep 5060
tcp 0 0 x.x.32.83:5060  0.0.0.0:*  LISTEN     1390/openser
udp 0 0 x.x.32.83:5060  0.0.0.0:*             1390/openser

Then I forwarded a message to a GW using TCP (lcr + t_relay):
(without force_send_socket)


  DEBUG: reply sent out. buf=0x8134330: SIP/2.0 1..., shmem=0x40680a90: 
SIP/2.0 1
  DEBUG: _reply_light: finished
  DEBUG: mk_proxy: doing DNS lookup...
  build_req_from_req: id added: <;i=1>, rcv proto=2
  parse_headers: flags=1000
  parse_headers: flags=1000
  parse_headers: flags=ffffffffffffffff
  clen_builder: content-length: 290 (290)
  check_via_address(x.x.33.3, 10.10.0.50, 0)
  tcp_send: no open tcp connection found, opening new one
  ERROR: tcp_blocking_connect: SO_ERROR (113) No route to host
  ERROR: tcpconn_connect: tcp_blocking_connect failed
  ERROR: tcp_send: connect failed
  msg_send: ERROR: tcp_send failed
  ERROR: t_forward_nonack: sending request failed


tcp_blocking_connect fails (the error message is a little bit misleading 
and caused by an ICMP error), as the GW accepts SIP only from .83, and 
not from .80: In the following tcpdump you see that openser tries to 
establish the TCP connection from .80 instead of .83:

IP x.x.32.80.41580 > x.x.33.4.5060: S
IP x.x.33.4 > x.x.32.80: icmp 36: host x.x.33.4 unreachable - admin 
prohibited filter


Any hints are appreciated.

Conclusion: openser sends .80 although it is bound to .83.

regards
Klaus


Bogdan-Andrei Iancu wrote:
> Hi Klaus,
> 
> not sure what you mean by "default interface", but here are some facts 
> after digging thought the code:
> 
> 1) when doing normal fwd (no force) on tcp, it will be used the first 
> TCP socket from the listen list; there is a funny comment from Andrei in 
> get_send_socket() function "on tcp just use the "main address", we don't 
> really now the sending address (we can find it out, but we'll need also 
> to see if we listen on it, and if yes on which port -> too complicated"
> 
> 2) if force_send_socket is used on tcp...depends.... do you get the 
> debug message:
>        "get_send_socket: force_send_socket of different proto(1)!"  ??
>    are you using t_relay() after??
>    what are the listening interfaces (all, udp and tcp)?
> 
> regards,
> bogdan
>  
> Klaus Darilion wrote:
> 
>> Hi!
>>
>> I've configured openser to listen on a ceratin IP address.
>>
>>   listen=83.xxx.32.83:5060
>>
>> Nevertheless, if t_relay tries to sned via TCP, openser opens the TCP 
>> connection from the default interface.
>>
>> I also tried
>>   force_send_socket(tcp:83.xxx.32.83:5060);
>> with the same results.
>>
>> Are there any known problems? IMO openser should always use the IP 
>> address on which it listens.
>>
>> regards
>> klaus
>>
>> _______________________________________________
>> Users mailing list
>> Users at openser.org
>> http://openser.org/cgi-bin/mailman/listinfo/users
>>
> 
> 





More information about the Users mailing list