在 Linux 系统中,可以通过以下方法查看 服务器开放和启用的端口。以下是详细的步骤和工具,适用于不同场景。


1. 使用 ss 查看开放的端口

ss 是一个现代化工具,用于显示网络连接和监听的端口。

1.1 查看正在监听的端口

运行以下命令:

bash

复制

ss -tuln
  • 参数说明
    • -t:显示 TCP 端口。
    • -u:显示 UDP 端口。
    • -l:仅显示监听的端口。
    • -n:以数字形式显示端口号(不解析为服务名称)。

示例输出

apache

复制

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    127.0.0.1:3306          0.0.0.0:*     
udp    UNCONN     0      0      0.0.0.0:123             0.0.0.0:*     
  • 解释
    • 0.0.0.0:22:表示所有网络接口上监听的 SSH 服务端口。
    • 127.0.0.1:3306:表示仅在本地监听的 MySQL 服务端口。

2. 使用 netstat 查看开放的端口

如果 ss 不可用,可以使用 netstat(部分系统需安装 net-tools 包)。

2.1 查看监听的端口

运行以下命令:

bash

复制

netstat -tuln
  • 参数说明
    • -t:显示 TCP 端口。
    • -u:显示 UDP 端口。
    • -l:仅显示监听的端口。
    • -n:以数字形式显示端口号。

示例输出

apache

复制

Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN
tcp        0      0 127.0.0.1:3306          0.0.0.0:*               LISTEN
udp        0      0 0.0.0.0:123             0.0.0.0:*

2.2 安装 net-tools(如果未安装)

在部分系统中,netstat 可能缺失,需要手动安装:

bash

复制

sudo apt install net-tools       # Ubuntu/Debian 系
sudo yum install net-tools       # CentOS/RHEL 系

3. 使用 lsof 查看开放的端口

lsof 是一个强大的工具,可以查看与端口相关的进程。

3.1 查看监听的端口

运行以下命令:

bash

复制

sudo lsof -i -P -n | grep LISTEN
  • 参数说明
    • -i:显示网络连接。
    • -P:显示端口号,而不是服务名称。
    • -n:避免解析域名,加快显示速度。

示例输出

apache

复制

sshd      1234    root    3u  IPv4  123456      0t0  TCP *:22 (LISTEN)
mysqld    2345    mysql   10u IPv4  654321      0t0  TCP 127.0.0.1:3306 (LISTEN)

4. 使用 firewall-cmd 查看防火墙开放的端口

如果服务器使用 Firewalld 作为防火墙,可以通过以下命令查看防火墙规则。

4.1 查看已开放的端口

运行以下命令:

bash

复制

sudo firewall-cmd --list-ports
  • 示例输出

    复制

    22/tcp 80/tcp 443/tcp
    
    • 表示 TCP 端口 22(SSH)、80(HTTP)、443(HTTPS)已开放。

4.2 查看所有防火墙规则

运行以下命令:

bash

复制

sudo firewall-cmd --list-all
  • 示例输出

    yaml

    复制

    public (active)target: defaulticmp-block-inversion: nointerfaces: eth0sources:services: ssh http httpsports: 22/tcp 80/tcp 443/tcpmasquerade: noforward-ports:source-ports:icmp-blocks:rich rules:
    

4.3 开放新端口

如果需要开放额外的端口(如 8080 TCP),可以运行:

bash

复制

sudo firewall-cmd --add-port=8080/tcp --permanent
sudo firewall-cmd --reload

5. 使用 iptables 查看防火墙规则

如果服务器使用的是 iptables 防火墙,可以通过以下命令查看规则。

5.1 查看所有规则

运行以下命令:

bash

复制

sudo iptables -L -n -v
  • 示例输出

    apache

    复制

    Chain INPUT (policy ACCEPT 0 packets, 0 bytes)pkts bytes target     prot opt in     out     source               destination100  5000 ACCEPT     tcp  --  *      *       0.0.0.0/0            0.0.0.0/0     tcp dpt:2250   3000 ACCEPT     tcp  --  *      *       0.0.0.0/0            0.0.0.0/0     tcp dpt:80
    

5.2 开放新端口

如果需要新增开放端口(如 8080 TCP),可以运行:

bash

复制

sudo iptables -A INPUT -p tcp --dport 8080 -j ACCEPT

6. 使用 nmap 扫描本地开放端口

nmap 是一个网络扫描工具,可以用于检查本地或远程服务器的开放端口。

6.1 安装 nmap

bash

复制

sudo apt install nmap       # Ubuntu/Debian 系
sudo yum install nmap       # CentOS/RHEL 系

6.2 扫描本地开放端口

运行以下命令:

bash

复制

sudo nmap -sT -p- 127.0.0.1
  • -sT:扫描 TCP 端口。
  • -p-:扫描所有端口(1-65535)。

示例输出

复制

Starting Nmap 7.80 ( https://nmap.org ) at 2023-08-16 10:00 UTC
Nmap scan report for localhost (127.0.0.1)
PORT      STATE SERVICE
22/tcp    open  ssh
80/tcp    open  http
443/tcp   open  https
3306/tcp  open  mysql

7. 总结

工具用途命令示例
ss查看监听的端口ss -tuln
netstat查看监听的端口netstat -tuln
lsof查看端口和相关进程`lsof -i -P -n
firewall-cmd查看防火墙开放的端口firewall-cmd --list-ports
iptables查看防火墙规则iptables -L -n -v
nmap扫描本地开放端口nmap -sT -p- 127.0.0.1

通过以上方法,您可以轻松检查 Linux 服务器上开放和启用的端口,并根据需要调整防火墙规则或开放新端口。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/95892.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/95892.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/95892.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

XF 306-2025 阻燃耐火电线电缆检测

近几年随着我国经济快速的发展,电气火灾呈现高发趋势,鉴于电线电缆火灾的危险性,国家制定了阻燃,耐火电线电缆的标准,为企业,建设方,施工方等的生产,选材提供了指引。XF 306-2025 阻…

【Java|第二十篇】面向对象(十)——枚举类

目录 (四)面向对象: 12、枚举类: (1)概述: (2)枚举类的定义格式: (3)编译与反编译: (4)Enum类…

第二十一天-OLED显示实验

一、OLED显示原理1、OLED名词解释OLED可以自发光,无需背光光源。2、正点原子OLED模块模块总体概述模块接口模式选择MCU与模块外部连接8080并口读写过程OLED显存因为要进行显示,所以需要有显存。显存容量为128 x 8 byte,一个点用一位表示。SSD…

会议系统核心流程详解:创建、加入与消息交互

一、系统架构概览 会议系统采用"主进程线程池进程池"的分层架构,实现高并发与业务隔离: #mermaid-svg-fDJ5Ja5L3rqPkby0 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-fDJ5Ja5L3r…

Spring 创建 Bean 的 8 种主要方式

Spring(尤其是 Spring Boot)提供了多种方式来让容器创建和管理 Bean。Component、Configuration Bean、EnableConfigurationProperties 都是常见方式。 下面我为你系统地梳理 Spring 创建 Bean 的所有主要方式,并说明它们的使用场景和区别。…

React 第七十节 Router中matchRoutes的使用详解及注意事项

前言 matchRoutes 是 React Router v6 提供的一个核心工具函数,主要用于匹配路由配置与当前路径。它在服务端渲染(SSR)、数据预加载、权限校验等场景中非常实用。下面详细解析其用法、注意事项和案例分析: 1、基本用法 import { m…

iSCSI服务配置全指南(含服务器与客户端)

iSCSI服务配置全指南(含服务器与客户端)一、iSCSI简介 1. 概念 互联网小型计算机系统接口(Internet Small Computer System Interface,简称iSCSI)是一种基于TCP/IP的协议,其核心功能是通过IP网络仿真SCSI高…

堆(Heap):高效的优先级队列实现

什么是堆?堆是一种特殊的完全二叉树,满足以下性质:堆序性:每个节点的值与其子节点满足特定关系最小堆:父节点 ≤ 子节点(根最小)最大堆:父节点 ≥ 子节点(根最大&#xf…

朝花夕拾(四) --------python中的os库全指南

目录 Python os模块完全指南:从基础到高阶文件操作 1. 引言:为什么需要os模块? 1.1 os模块的重要性 1.2 适用场景 1.3 os模块的"瑞士军刀"特性 2. os模块基础功能 2.1 文件与目录操作 2.1.1 核心方法介绍 2.1.2 避坑指南 …

uniappx 安卓端本地打包的一些总结

本人之前没用过android studio,因为有打包到安卓端的需求,所以有了这篇文章。下面一些内容不正常工作,也不报错,是很烦的,根本不知道是哪里出了问题。比如对应的aar包没有引入。或者没有注册信息。 在实现过程中我遇到…

AUTOSAR进阶图解==>AUTOSAR_SWS_UDPNetworkManagement

AUTOSAR UDP网络管理详解 基于AUTOSAR标准的UDP网络管理模块架构分析与实现指南目录 1. 概述2. UDP网络管理架构 2.1 整体架构图2.2 架构组件详解 3. UDP网络管理状态机 3.1 状态机图3.2 状态详解 4. UDP网络管理操作序列 4.1 序列图4.2 操作流程详解 5. UDP网络管理配置模型 …

AI搜索引擎下的内容优化新范式:GEO的关键技术解析

摘要: 生成式AI搜索引擎的崛起,催生了GEO(Generative Engine Optimization)这一新的优化领域。本文将深入剖析GEO背后的关键技术,包括深度语义理解、结构化内容生成、以及AI算法的适配性,旨在为品牌在AI时代…

Java Lambda表达式是什么,怎么用

这种代码是什么&#xff0c;怎么阅读/*** 批量插入** param entityList ignore* param batchSize ignore* return ignore*/Transactional(rollbackFor Exception.class)Overridepublic boolean saveBatch(Collection<T> entityList, int batchSize) {String sqlStateme…

集成运算放大器(反向加法,减法)

反向加法电路原理&#xff1a;示波器显示&#xff1a;结论&#xff1a;输出电压-&#xff08;R4/R1*V1R4/R2*V2R4/R3*V3&#xff09;。平衡电阻R4等于R1和R2和R3的并联电压。减法运算电路原理&#xff1a;结论&#xff1a;减法运算电路分为三种不同情况&#xff0c;第一种情况为…

Maven入门到精通

目录 一&#xff0c;Maven概述 1.1介绍 1.2安装 1.3Maven生命周期和插件 1.4Maven的坐标的本地仓库的存储地址 二&#xff0c;依赖管理 2.1依赖管理——依赖范围 2.2依赖管理——添加依赖 获取依赖坐标 依赖添加后的操作 2.3依赖管理——依赖传递 2.4依赖管理——依…

计算机网络 TCP 延迟确认机制

TCP 延迟确认&#xff08;Delayed Acknowledgments&#xff0c;简称 Delayed ACK&#xff09;是 TCP 协议中一项旨在减少网络中小数据包数量、提升传输效率的优化机制。其核心思想是&#xff1a;不立即回复 ACK&#xff0c;而是等待一段时间&#xff08;通常 40ms&#xff09;&…

【visual studio】visual studio配置环境opencv和onnxruntime

下载opencv https://opencv.org/releases/?spma2ty_o01.29997173.0.0.57f4c921RELipW配置环境变量visual studio配置opencv 新建c项目选中文件后右键选择属性添加include文件夹库文件添加lib添加lib文件 将上一步的lib文件夹下的两个文件复制到这里以下两者区别在于&#xff0…

【Java】多线程Thread类

1. 进程与线程进程与线程的基本认识进程&#xff08;Process&#xff09;&#xff1a;进程是程序的一次动态执行过程&#xff0c;它经历了从代码加载、执行、到执行完毕的一个完整过程&#xff1b;同时也是并发执行的程序在执行过程中分配和管理资源的基本单位&#xff0c;竞争…

C/C++复习(四)

一.模版 模版涉及的是泛型编程&#xff0c;即通过编译器去确定类型的编程方式&#xff0c;模版分为&#xff1a;类模板和函数模版&#xff0c;下面我们一一复习&#xff1a; 函数模版&#xff1a; 格式&#xff1a; template<typename T1, typename T2,......,typename Tn&g…

022 基础 IO —— 文件

&#x1f984; 个人主页: 小米里的大麦-CSDN博客 &#x1f38f; 所属专栏: Linux_小米里的大麦的博客-CSDN博客 &#x1f381; GitHub主页: 小米里的大麦的 GitHub ⚙️ 操作环境: Visual Studio 2022 文章目录基础 IO —— C 语言文件 I/O 操作基础前言1. C 语言文件操作函数汇…