我有一个 AST2600 evb 板。开机后(连接 RJ45),它启动到 OpenBMC 内核。从串口,使用ip
命令我可以获得它的IP地址。在我的笔记本电脑上,我可以ssh
使用 account 进入董事会root/0penBmc
:
bruin@gen81:/$ ssh root@192.168.6.132
root@192.168.6.132's password:
然后我想知道哪些 tcp 端口是开放的。由于没有ss
//实用程序,我lsof
:netstat
cat /proc/net/tcp
root@AMIfa7ba648f62e:/proc/net# cat /proc/net/tcp
sl local_address rem_address st tx_queue rx_queue tr tm->when retrnsmt uid timeout inode
0: 00000000:14EB 00000000:0000 0A 00000000:00000000 00:00000000 00000000 997 0 9565 1 0c202562 100 0 0 10 0
1: 3500007F:0035 00000000:0000 0A 00000000:00000000 00:00000000 00000000 997 0 9571 1 963c8114 100 0 0 10 0
奇怪的是,tcp 端口 22 并没有在 中列出/proc/net/tcp
,这表明没有进程正在侦听 tcp 端口 22。如果是这样,那么 ssh 连接是如何建立的?
顺便说一句,正如使用 测试的那样ps
,它dropbear
是处理 ssh 连接的进程,并且dropbear
是动态生成的(即,如果没有 ssh 连接,则不存在这样的进程;如果我建立了两个 ssh 连接,dropbear
则生成了两个进程)。
PS:正如约翰在他的回复中所建议的,我将ss
实用程序添加到图像中,它显示了我的预期:
root@AMI8287361b9c6f:~# ss -antp
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 0 0.0.0.0:5355 0.0.0.0:* users:(("systemd-resolve",pid=239,fd=12))
LISTEN 0 0 127.0.0.1:5900 0.0.0.0:* users:(("obmc-ikvm",pid=314,fd=5))
LISTEN 0 0 127.0.0.53:53 0.0.0.0:* users:(("systemd-resolve",pid=239,fd=17))
LISTEN 0 0 *:443 *:* users:(("bmcweb",pid=325,fd=3),("systemd",pid=1,fd=41))
LISTEN 0 0 *:5355 *:* users:(("systemd-resolve",pid=239,fd=14))
LISTEN 0 0 *:5900 *:* users:(("obmc-ikvm",pid=314,fd=6))
LISTEN 0 0 *:22 *:* users:(("systemd",pid=1,fd=49))
LISTEN 0 0 *:2200 *:* users:(("systemd",pid=1,fd=50))
ESTAB 0 0 [::ffff:192.168.6.89]:22 [::ffff:192.168.6.98]:34906 users:(("dropbear",pid=485,fd=2),("dropbear",pid=485,fd=1),("dropbear",pid=485,fd=0),("systemd",pid=1,fd=20))