por que o ss (8) entende as portas UDP de escuta de maneira diferente do netstat (8)?

8

Se eu executar ss -lupara visualizar todos os soquetes UDP de escuta, nenhum deles será exibido. Se eu executar ss -au, que lista todos os soquetes UDP (de escuta e não escuta), os soquetes de "escuta" são exibidos como UNCONN:

T60:~ # lsof -n | sed -n '1p;/UDP/p'
COMMAND     PID   TID       USER   FD      TYPE     DEVICE SIZE/OFF       NODE NAME
avahi-dae   963            avahi   11u     IPv4       9088      0t0        UDP *:mdns 
avahi-dae   963            avahi   12u     IPv4       9089      0t0        UDP *:44639 
cupsd      1238             root   10u     IPv4       8160      0t0        UDP *:ipp 
dhcpcd     2072             root    7u     IPv4     532052      0t0        UDP *:bootpc 
dhclient6 13131             root    5u     IPv6      38031      0t0        UDP *:dhcpv6-client 
dhclient6 13131             root   20u     IPv4      37954      0t0        UDP *:20152 
dhclient6 13131             root   21u     IPv6      37955      0t0        UDP *:36745 
atftpd    20639             tftp    0u     IPv4     344977      0t0        UDP *:tftp 
T60:~ # netstat -lu
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
udp        0      0 *:bootpc                *:*                                 
udp        0      0 *:tftp                  *:*                                 
udp        0      0 *:44639                 *:*                                 
udp        0      0 *:ipp                   *:*                                 
udp        0      0 *:20152                 *:*                                 
udp        0      0 *:mdns                  *:*                                 
udp        0      0 *:36745                 *:*                                 
udp        0      0 *:dhcpv6-client         *:*                                 
T60:~ # ss -lu
Recv-Q Send-Q                                                                                                          Local Address:Port                                                                                                              Peer Address:Port   
T60:~ # ss -ua
State       Recv-Q Send-Q                                                                                                     Local Address:Port                                                                                                         Peer Address:Port   
UNCONN      0      0                                                                                                                      *:bootpc                                                                                                                  *:*       
UNCONN      0      0                                                                                                                      *:tftp                                                                                                                    *:*       
UNCONN      0      0                                                                                                                      *:44639                                                                                                                   *:*       
UNCONN      0      0                                                                                                                      *:ipp                                                                                                                     *:*       
UNCONN      0      0                                                                                                                      *:20152                                                                                                                   *:*       
UNCONN      0      0                                                                                                                      *:mdns                                                                                                                    *:*       
UNCONN      0      0                                                                                                                     :::36745                                                                                                                  :::*       
UNCONN      0      0                                                                                                                     :::dhcpv6-client                                                                                                                :::*       
T60:~ # ss -v
ss utility, iproute2-ss110629
T60:~ # 

Qual é a lógica por trás disso? Por exemplo, executando o atftpd atendendo a conexões, deve ter o estado LISTEN e não UNCONN, não deveria?

Martin
fonte
Talvez apenas palavras? Um soquete de escuta é, obviamente, alheio ... ;-)
Hauke Laging
1
@HaukeLaging Para não falar tanto som ruim considerando UDP :)
TNW
Notei que o comportamento -ulvaria entre RHEL5 e RHEL6. Não faz sentido para o RHEL5, mas o RHEL6 faz o que você esperaria. (o estado ainda é listado como UNCONNna saída, mas ele só mostra os ouvintes)
Andrew B

Respostas:

4

UDP é um protocolo sem conexão. O SS provavelmente não mostrará um no estado LISTEN, apenas no UCONN ou ESTAB.

Se eu fizer isso,

$ nc -u -l 2333

Então o ss mostrará (no segundo shell):

$ ss -au|grep 2333
UNCONN     0      0                       *:2333                     *:*       

Se eu conectar a ele (terceiro shell)

$ nc -u localhost 2333

então SS mostra:

$ ss -au|grep 2333
ESTAB      0      0               127.0.0.1:2333             127.0.0.1:58434   
ESTAB      0      0               127.0.0.1:58434            127.0.0.1:2333    
mitchell perilstein
fonte