(возможно, вам придется установить пакет ip
на openwrt (v12 / регулировка ориентации)
ifconfig / netstat и т.д. считаются устаревшими , поэтому вы должны использовать (как root)
ss -nlput | grep sshd
показать сокеты TCP / UDP, на которых sshd
слушает работающая программа, содержащая строку
-n
нет порта для разрешения имени
-l
только прослушивающие розетки
-p
показать процессы прослушивания
-u
показать сокеты udp
-t
показать сокеты tcp
Затем вы получаете список, как этот:
tcp LISTEN 0 128 *:22 *:* users:(("sshd",3907,4))
tcp LISTEN 0 128 :::22 :::* users:(("sshd",3907,3))
tcp LISTEN 0 128 127.0.0.1:6010 *:* users:(("sshd",4818,9))
tcp LISTEN 0 128 ::1:6010 :::* users:(("sshd",4818,8))
интересным является 5-й столбец, который показывает комбинацию IP-адреса и порта:
*:22
прослушивать порт 22 на каждом доступном IPv4-адресе
:::22
прослушивать порт 22 на каждом доступном IP-адресе (я не пишу IPv6, так как IP - это IPv6 для RFC 6540 )
127.0.0.1:6010
прослушивание IPv4-адреса 127.0.0.1 (localhost / loopback) и порта 6010
::1:6010
прослушивать IP-адрес :: 1 (0: 0: 0: 0: 0: 0: 0: 1 в полной нотации, а также localhost / loopback) и порт 6010
Затем вы хотите узнать, какие интерфейсы имеют адрес IPv4 (для покрытия 1.)
ip -4 a
# or "ip -4 address"
# or "ip -4 address show"
или IP-адрес (для покрытия 2.)
ip -6 a
# or "ip -6 address
# or "ip -6 address show
(если вы не добавите опцию для IP ( -6
) или IPv4 ( -4
), оба будут показаны)
Вы также можете посмотреть, что вывод и поиск, например, 127.0.0.1
или любой другой IP / IPv4-адрес
# here a demo where i show all addresses of the device "lo" (loopback)
ip a show dev lo
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
Строки, начинающиеся с inet
и inet6
показывающие, что эти IP-адреса привязаны к этому интерфейсу, могут иметь много таких строк на интерфейс:
he-ipv6: <POINTOPOINT,NOARP,UP,LOWER_UP> mtu 1480 qdisc noqueue state UNKNOWN
link/sit 192.0.2.1 peer 192.0.2.3
inet6 2001:db8:12::1/64 scope global
valid_lft forever preferred_lft forever
inet6 2001:db8::2/64 scope global
valid_lft forever preferred_lft forever
inet6 fe80::1111:1111/128 scope link
valid_lft forever preferred_lft forever
и в скрипте:
address="127.0.0.1"
for i in $(grep ':' /proc/net/dev | cut -d ':' -f 1 | tr -d ' ') ; do
if $(ip address show dev $i | grep -q "${address}") ; then
echo "${address} found on interface ${i}"
fi
done
(заменить "127.0.0.1")