在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
-t
:显示TCP连接。-u
:显示UDP连接。-l
:仅显示监听状态的套接字。-n
:以数字形式显示地址和端口号。示例输出:
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 0.0.0.0:22 0.0.0.0:*
LISTEN 0 128 [::]:80 [::]:*
UNCONN 0 0 0.0.0.0:123 0.0.0.0:*
lsof
命令lsof
可以列出当前系统打开的文件和使用这些文件的进程。
sudo lsof -i -P -n | grep LISTEN
-i
:显示网络文件。-P
:不将端口号转换为服务名称。-n
:不将IP地址转换为主机名。示例输出:
sshd 1234 root 3u IPv4 12345 0t0 TCP *:22 (LISTEN)
nginx 5678 www-data 6u IPv4 23456 0t0 TCP *:80 (LISTEN)
nmap
工具nmap
是一个网络扫描工具,可以用来探测主机上的开放端口。
sudo nmap -sS -O localhost
-sS
:使用SYN扫描。-O
:尝试识别操作系统。示例输出:
Starting Nmap 7.91 ( https://nmap.org ) at 2023-04-01 12:34:56 UTC
Nmap scan report for localhost (127.0.0.1)
Host is up (0.00018s latency).
Not shown: 997 closed ports
PORT STATE SERVICE
22/tcp open ssh
80/tcp open http
123/udp open ntp
sudo
提升权限。netstat
或 ss
命令未找到。apt-get install net-tools
安装 netstat
。grep
过滤特定端口或服务。通过以上方法,你可以有效地查看Linux系统中哪些端口是打开的,并根据需要进行进一步的管理和调试。
领取专属 10元无门槛券
手把手带您无忧上云