在Linux系统中,查看端口开启情况可以通过多种命令来实现,以下是一些常用的方法:
netstat
命令netstat
是一个网络统计工具,可以显示网络连接、路由表、接口统计等。
netstat -tuln
-t
:显示TCP端口。-u
:显示UDP端口。-l
:仅显示监听套接字。-n
:以数字形式显示地址和端口号。示例输出:
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
tcp6 0 0 :::80 :::* LISTEN
udp 0 0 0.0.0.0:123 0.0.0.0:*
ss
命令ss
是 netstat
的替代品,性能更好,显示的信息更详细。
ss -tuln
示例输出:
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 5 0.0.0.0:22 0.0.0.0:*
LISTEN 0 128 *:80 *:*
lsof
命令lsof
可以列出当前系统打开的文件和使用这些文件的进程。
sudo lsof -i -n -P | grep LISTEN
-i
:显示网络文件。-n
:不将IP地址转换为域名。-P
:不将端口号转换为服务名。示例输出:
sshd 1234 root 3u IPv4 12345 0t0 TCP *:22 (LISTEN)
nginx 5678 www-data 6u IPv4 23456 0t0 TCP *:80 (LISTEN)
原因:
解决方法:
sudo
提升权限:sudo
提升权限:原因: 可能是进程异常退出,但端口仍处于TIME_WAIT状态。
解决方法:
等待一段时间,端口会自动释放;或者使用 sysctl
调整内核参数加速回收:
sudo sysctl -w net.ipv4.tcp_fin_timeout=30
通过以上方法,可以有效查看Linux系统中的端口开启情况,并解决常见的相关问题。
领取专属 10元无门槛券
手把手带您无忧上云