Linux查询端口号

一、基础概念

端口号是网络通信中的一个概念,用于标识一条通信链路的端点,主要用于标识不同的服务。

常用的端口号被固定分配给了一些常用的服务,如FTP、HTTP、SSH等;除此之外,还有大量的私有端口号未被固定分配,在使用时需要协商双方自定义。

在Linux中,所有的网络通信都是基于socket来实现的,而socket通信的两个端点都会被绑定到一个端口号以区别不同的通信链路。

二、查询端口号的方法

1. netstat命令

$ netstat -tlnp

该命令可以列出当前系统中所有的TCP和UDP端口号以及占用端口号的进程,其中:

  • -t表示列出所有的TCP协议
  • -u表示列出所有的UDP协议
  • -l表示列出所有的正在监听的端口号
  • -n表示不对端口号进行反向域名解析,提高命令执行速度
  • -p表示显示占用端口号的进程PID及名称

示例:

Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1234/sshd           
tcp6       0      0 :::80                   :::*                    LISTEN      5678/httpd          
udp        0      0 0.0.0.0:68              0.0.0.0:*                           901/dhclient        

可以看到当前系统中TCP协议下22端口号被sshd进程占用,TCP协议下80端口号被httpd进程占用,UDP协议下68端口号被dhclient进程占用。

2. lsof命令

$ sudo lsof -i :端口号

该命令可以查询指定端口号的占用进程,其中:

  • -i表示查询网络相关文件
  • -p表示查询指定进程PID相关的文件

示例:

COMMAND    PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
sshd      1234 root    3u  IPv4  12345      0t0  TCP *:ssh (LISTEN)

可以看到22端口号被sshd进程占用。

3. ss命令

$ ss -ltnp | grep :端口号

该命令可以列出指定端口号的占用进程,其中:

  • -l表示只列出监听状态的端口号
  • -t表示只列出TCP协议相关的端口号
  • -n表示不对端口号进行反向域名解析,提高命令执行速度
  • -p表示显示占用端口号的进程PID及名称

示例:

LISTEN   0         128                0.0.0.0:22            0.0.0.0:*      users:(("sshd",1234,3))

可以看到22端口号被sshd进程占用。

三、防火墙对端口号的管理

在Linux中,防火墙是管理网络连接的基本手段之一。

1. 查询防火墙状态

$ sudo systemctl status firewalld

该命令可以查询当前防火墙的运行状态。

2. 查询防火墙规则

$ sudo firewall-cmd --list-all

该命令可以列出当前系统中所有的防火墙规则及其对应的端口号。

3. 打开/关闭端口号

$ sudo firewall-cmd --add-port=端口号/tcp --permanent
$ sudo firewall-cmd --remove-port=端口号/tcp --permanent

该命令可以分别打开/关闭指定的端口号,并将规则永久写入防火墙配置中。

四、小结

本文介绍了在Linux系统中查询端口号的几种方法,包括使用netstat、lsof、ss命令查询,同时还介绍了防火墙对端口号的管理方法。

原创文章,作者:NVQV,如若转载,请注明出处:https://www.506064.com/n/136295.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
NVQVNVQV
上一篇 2024-10-04 00:16
下一篇 2024-10-04 00:16

相关推荐

  • 如何修改mysql的端口号

    本文将介绍如何修改mysql的端口号,方便开发者根据实际需求配置对应端口号。 一、为什么需要修改mysql端口号 默认情况下,mysql使用的端口号是3306。在某些情况下,我们需…

    编程 2025-04-29
  • 如何在Linux中添加用户并修改配置文件

    本文将从多个方面详细介绍在Linux系统下如何添加新用户并修改配置文件 一、添加新用户 在Linux系统下创建新用户非常简单,只需使用adduser命令即可。使用以下命令添加新用户…

    编程 2025-04-27
  • 如何解决linux jar包 invalid or corrupt jarfile问题

    对于许多开发人员和系统管理员在Linux环境下使用Java开发过程中遇到的一个常见的问题是 invalid or corrupt jarfile(无效或损坏的jar文件)错误。当您…

    编程 2025-04-27
  • 在Linux上安装JRE并配置环境变量

    本文将从以下几个方面为您详细阐述如何在Linux系统上,通过自己账户安装JRE,并且配置环境变量。 一、安装JRE 在进行安装前,我们需要下载JRE的安装包并解压,可以从官方网站下…

    编程 2025-04-27
  • GTKAM:Linux下的照片管理器

    GTKAM是用于Linux操作系统的一款照片管理器,它支持多种相机及存储设备,并提供了一系列强大的工具,让用户可以方便地浏览、管理、编辑和导出照片。本文将从多个方面对GTKAM进行…

    编程 2025-04-27
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • 如何在Windows/Linux/MacOS下安装Python

    如果你对Python安装一无所知,本文将从多个方面对Python在Windows/Linux/MacOS下的安装做出详细阐述,为初学者提供帮助。 一、Windows下Python的…

    编程 2025-04-25
  • Linux网络连接激活失败原因及解决方法

    一、网卡驱动问题 1、缺少网卡驱动 若使用新的网卡,需要安装对应网卡驱动,否则会导致网络连接激活失败。可通过以下命令查看当前系统中是否存在网卡驱动: lsmod | grep et…

    编程 2025-04-25
  • Linux Redis 重启

    一、概述 Redis 是一款高性能的 NoSQL 数据库,常用于各种应用场景的数据缓存、消息队列、实时数据分析等等。在使用 Redis 过程中,如果出现了某些问题,有时候只需要重启…

    编程 2025-04-25

发表回复

登录后才能评论