Linux中如何查看服务及监听端口

本文介绍如何在*NIX系统中使用Lsof和Netstat命令来查看哪些服务正在特定端口上监听。通过命令示例展示了如何针对IPv4和IPv6协议下的端口进行查询,并解释了常用参数的功能。
问:我该如何发现哪种服务正在某个特定端口上监听呢?我如何发现哪一个程序正在一个特定端口上监听呢?

  答:在*NIX系统中,你可以使用下面的任何一个命令来得到在一个特定TCP端口上监听的列表。

  Lsof:其功能是列示打开的文件,包括监听端口。

  netstat :此命令象征性地展示各种与网络有关的数据和信息的内容。

  Lsof命令示例

  你可以输入下面的命令来查看IPv4端口:

  # lsof -Pnl +M -i4

  你可以输入下面的命令来查看IPv6协议下的端口列示:

  # lsof -Pnl +M -i6

  此例输出:

      1

  这里我们不妨解释一 下。第一栏是command,它给出了程序名称的有关信息。请注意标题的细节。例如,第二行的gweather* 命令从美国 NWS服务器(140.90.128.70)获取天气的报告信息,包括交互天气信息网络和其它的天气服务。在这里,我们解释一下命令各个参数。

  1. -P :这个选项约束着网络文件的端口号到端口名称的转换。约束转换可以使lsof运行得更快一些。在端口名称的查找不能奏效时,这是很有用的。

  2. -n : 这个选项约束着网络文件的端口号到主机名称的转换。约束转换可以使lsof的运行更快一些。在主机名称的查找不能奏效时,它非常有用。

  3. -l :这个选项约束着用户ID号到登录名的转换。在登录名的查找不正确或很慢时,这个选项就很有用。

  4. +M :此选项支持本地TCP和UDP端口映射程序的注册报告。

  5. -i4 :仅列示IPv4协议下的端口。

  6. -i6 : 仅列示IPv6协议下的端口。

  Netstaty命令举例

  请输入下面的命令:

  # netstat -tulpn

  或者是

  # netstat -npl

  请看输出结果::

  Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name

  tcp 0 0 0.0.0.0:6881 0.0.0.0:* LISTEN 6908/python

  tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 5562/cupsd

  tcp 0 0 127.0.0.1:3128 0.0.0.0:* LISTEN 6278/(squid)

  tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 5854/exim4

  udp 0 0 0.0.0.0:32769 0.0.0.0:* 6278/(squid)

  udp 0 0 0.0.0.0:3130 0.0.0.0:* 6278/(squid)

  udp 0 0 0.0.0.0:68 0.0.0.0:* 4583/dhclient3

  udp 0 0 0.0.0.0:6881 0.0.0.0:* 6908/python

  请注意,最后一栏给出了关于程序名称和端口的信息。在这里,我们解释一下各参数的含义:

  -t : 指明显示TCP端口

  -u : 指明显示UDP端口

  -l : 仅显示监听套接字(所谓套接字就是使应用程序能够读写与收发通讯协议(protocol)与资料的程序)

  -p : 显示进程标识符和程序名称,每一个套接字/端口都属于一个程序。

  -n : 不进行DNS轮询(可以加速操作)

  关于/etc/services文件

  /etc/services是一个纯ASCII文件,它可以提供互联网服务的友好文本名称,还有其默认分配的端口号和协议类型。每一个网络程序都要进入这个文件得其服务的端口号(和协议)。你可以借助于cat命令或less命令等来查看这个文件:

  $ cat /etc/services

  $ grep 110 /etc/services

  $ less /etc/services

  

<think> 我们正在讨论如何查看Linux系统中的所有监听端口。参考了之前的引用内容,其中提到了使用`netstat`和`lsof`命令,以及防火墙相关命令(但防火墙命令主要用于管理端口而非查看监听端口#,所以主要关注查看方法#。 根据引用#[1]和[2],重点强调查看监听端口方法#,以下整理三种常用方法: 1. **使用 `netstat` 命令** `netstat` 是经典工具#,能显示网络连接#、路由表#、接口统计等信息。查看监听端口命令: `netstat -tuln` 参数说明: `-t`:TCP端口 `-u`:UDP端口 `-l`:仅显示监听套接字 `-n`:以数字形式显示地址和端口号(而非服务名) **完整命令**: `sudo netstat -tuln | grep LISTEN` 注意:部分系统需root权限才能查看所有进程的端口 2. **使用 `lsof` 命令** `lsof`(List Open Files)可列出被进程打开的文件(含网络套接字)。 命令格式: `sudo lsof -i -P -n | grep LISTEN` 参数解释: `-i`:列出网络连接 `-P`:禁止端口服务名的转换(纯数字显示) `-n`:禁止主机名解析(显示IP) `grep LISTEN`:过滤出监听状态端口 3. **使用 `ss` 命令(推荐)** `ss`(Socket Statistics)是`netstat`的现代替代品#,速度更快且信息更详细#。 命令:`sudo ss -tuln` 参数说明: `-t`:TCP端口 `-u`:UDP端口 `-l`:仅监听端口 `-n`:数字格式显示 </think> 在 Linux 系统查看所有监听端口,可以通过以下几种常用方法实现(需注意部分命令需要 root 权限): --- ### **1. 使用 `netstat` 命令(经典工具)** ```bash sudo netstat -tuln | grep LISTEN ``` - **参数说明**: - `-t`:显示 TCP 端口 - `-u`:显示 UDP 端口 - `-l`:仅显示监听状态的端口 - `-n`:以数字形式显示地址和端口号(不解析服务名称) - 示例输出: ```bash 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 ``` - **注**:部分系统需 `sudo` 权限才能查看所有进程的端口。 --- ### **2. 使用 `lsof` 命令(查看进程关联)** ```bash sudo lsof -i -P -n | grep LISTEN ``` - **参数说明**: - `-i`:列出网络连接 - `-P`:禁止端口服务名的转换(显示数字端口) - `-n`:禁止主机名解析(显示 IP 地址) - **输出示例**: ```bash COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME sshd 1234 root 3u IPv4 23456 0t0 TCP *:22 (LISTEN) nginx 5678 www 6u IPv6 78901 0t0 TCP *:80 (LISTEN) ``` --- ### **3. 使用 `ss` 命令(推荐,更高效)** ```bash sudo ss -tuln ``` - **参数说明**: - `-t`:TCP 端口 - `-u`:UDP 端口 - `-l`:仅显示监听端口 - `-n`:数字格式显示(不解析服务名) - **输出示例**: ```bash Netid State Recv-Q Send-Q Local Address:Port Peer Address:Port tcp LISTEN 0 128 0.0.0.0:22 0.0.0.0:* tcp LISTEN 0 128 [::]:80 [::]:* ``` --- ### **4. 查看防火墙开放端口(额外参考)** 若需确认防火墙是否放行端口(非监听状态),可参考引用[3]: ```bash sudo firewall-cmd --list-ports # 查看永久开放的端口 sudo firewall-cmd --list-all # 查看详细规则 ``` --- ### **注意事项** 1. **权限问题**:普通用户可能无法查看系统进程的端口,建议使用 `sudo` 2. **端口服务对应**: - 查看 `/etc/services` 文件可获知端口默认服务名 - 示例:`grep 80 /etc/services` 显示 `http` 服务 3. **监听范围**: - `0.0.0.0` 表示监听所有 IPv4 地址 - `::` 表示监听所有 IPv6 地址 > **引用说明**: > - 方法 1 引用自 `netstat` 监听端口检测[^1] > - `ss` 命令作为 `netstat` 的现代替代方案,速度更快且信息更详细[^2] ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值