Как правильно вызвать lsof для получения всех TCP-соединений?

14
# lsof -n -itcp | wc
     92     919   10212

# lsof -n | grep TCP | wc
   2482   27222  373861

Что я делаю не так lsof -itcp? Такой вызов пропускает часть соединений, похоже, это соединения потоков.

вектор
источник

Ответы:

16

Правильный синтаксис:

lsof -a -i4 -i6 -itcp

Это выбирает сокеты TCP, которые являются IPv4 или IPv6.

CodeWriter23
источник
1
Вы должны добавить -aк этому И их
Кристиан
Спасибо, Кристиан, мое оригинальное решение включало в себя и UDP-активность. Обновлено.
CodeWriter23
1

Посмотрите на два выхода. Вот образцы из моей системы

lsof -n -itcp | head -4
COMMAND     PID        USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rpcbind    1509        root    8u  IPv4   9013      0t0  TCP *:sunrpc (LISTEN)
rpcbind    1509        root   11u  IPv6   9016      0t0  TCP *:sunrpc (LISTEN)
rpc.statd  1537       statd    8u  IPv4  10059      0t0  TCP *:36035 (LISTEN)

lsof -n | grep TCP | head -4
rpcbind    1509             root    8u     IPv4               9013      0t0        TCP *:sunrpc (LISTEN)
rpcbind    1509             root   11u     IPv6               9016      0t0        TCP *:sunrpc (LISTEN)
rpc.statd  1537            statd    8u     IPv4              10059      0t0        TCP *:36035 (LISTEN)
rpc.statd  1537            statd   10u     IPv6              10063      0t0        TCP *:45203 (LISTEN)

Быстрое прочтение показывает, что единственными очевидными различиями на данный момент являются пробелы. Это можно сравнить достаточно легко, чтобы найти реальные различия:

lsof -n -itcp | sort >1
lsof -n | grep TCP | sort >2
diff -wu 1 2 | grep '^[+-]'
--- 1   2015-10-13 20:43:12.588658249 +0100
+++ 2   2015-10-13 20:43:18.272678740 +0100
-COMMAND     PID        USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
+dconf      3618 3634     roaima   11u     IPv6              12705      0t0        TCP [::1]:45177->[::1]:6010 (ESTABLISHED)
+gdbus      3632 3633     roaima    5u     IPv6              14008      0t0        TCP [::1]:45179->[::1]:6010 (ESTABLISHED)
+virt-mana  3618 3636     roaima   11u     IPv6              12705      0t0        TCP [::1]:45177->[::1]:6010 (ESTABLISHED)
+virt-mana  3618 3645     roaima   11u     IPv6              12705      0t0        TCP [::1]:45177->[::1]:6010 (ESTABLISHED)

Основываясь на этом выводе, я бы предположил, что разница в моем случае - трафик IPv6. Возможно, вы захотите пересмотреть свою собственную ситуацию, но я подозреваю, что это то же самое.

roaima
источник