百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

如何检查 Linux 中开放的端口列表?

nanshan 2025-03-04 13:17 10 浏览 0 评论

在Linux系统中,开放端口是网络通信的核心枢纽,也是潜在安全风险的入口。无论是作为系统管理员还是开发者,掌握开放端口的检测方法不仅能帮助排查服务故障,更是加固系统安全的第一道防线。本文将深入解析8种主流检测技术,涵盖从命令行工具到自动化监控的完整解决方案,助您构建全方位的端口管理能力。

基础工具篇

快速定位开放端口

1. netstat:经典网络状态分析利器

适用场景:实时查看当前活跃连接与监听端口

核心命令

sudo netstat -tuln
  • -t:显示TCP协议端口
  • -u:显示UDP协议端口
  • -l:仅列出监听状态(LISTEN)的端口
  • -n:以数字形式显示地址和端口(避免DNS反向解析)

输出解读示例

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

注:0.0.0.0:22表示在所有IPv4接口监听22端口(SSH服务)

2. ss:netstat的高性能替代品

优势:速度更快、信息更详细

常用参数组合

sudo ss -tulnp
  • -p:显示关联进程信息(需root权限)
  • -4/-6:单独筛选IPv4或IPv6地址

进程关联输出

Netid  State   Recv-Q  Send-Q  Local Address:Port   Peer Address:Port
tcp    LISTEN  0       128     0.0.0.0:80           0.0.0.0:*       users:(("nginx",pid=1234,fd=6))

关键信息:Nginx进程(PID 1234)正在监听80端口

3. lsof:基于进程的深度检测

特殊价值:精准定位端口占用进程的完整路径

执行命令

sudo lsof -i :22

二、高级扫描篇

穿透防火墙的探测技术

4. nmap:网络安全审计的瑞士军刀

功能亮点:跨网段扫描、服务指纹识别

基础扫描命令

sudo nmap -sT -p 1-65535 127.0.0.1
  • -sT:TCP全连接扫描(准确性高但速度较慢)
  • -sS:SYN半开扫描(需root权限,速度快)
  • -p:指定端口范围(避免扫描全部65535端口)

智能扫描策略

nmap -T4 -F 192.168.1.0/24
  • -T4:加速扫描节奏
  • -F:快速模式(仅扫描常见100个端口)

5. telnet/nc:手动验证端口可达性

实战示例

telnet 192.168.1.100 3306
# 若返回"Connected to 192.168.1.100"表示MySQL端口开放

nc -zvw3 192.168.1.100 1-1024
  • -z:零I/O模式(仅检测连接)
  • -w3:设置3秒超时

三、防火墙视角

管理端口放行规则

6. iptables:传统防火墙规则查询

sudo iptables -L -n -v

重点观察Chain INPUT中的ACCEPT规则

7. ufw:Ubuntu系防火墙管理

sudo ufw status verbose

输出样例

Status: active
Logging: on (low)
Default: deny (incoming), allow (outgoing)

To         Action  From
--         ------  ----
22/tcp     ALLOW   Anywhere
80/tcp     ALLOW   192.168.1.0/24

8. firewalld:CentOS/RHEL防火墙控制

sudo firewall-cmd --list-all

关键信息

ports: 22/tcp 80/tcp 443/tcp
services: dhcpv6-client ssh

四、图形化工具推荐

适合新手的可视化方案

  1. Wireshark

实时抓包分析TCP/UDP通信流量

  1. Zenmap

nmap官方GUI工具,支持拓扑图绘制

  1. GNOME Network Tools

集成端口扫描、路由追踪等实用功能

五、自动化监控方案

1. 定时任务脚本示例

#!/bin/bash
DATE=$(date +%Y%m%d)
ss -tuln > /var/log/ports_$DATE.log
diff /var/log/ports_$(date -d yesterday +%Y%m%d).log /var/log/ports_$DATE.log

2. Prometheus + Grafana监控架构

  • 通过node_exporter收集端口数据
  • 配置告警规则检测异常端口开放

六、安全加固黄金法则

  1. 最小化开放原则

关闭非必要端口(如关闭SSH的TCP 22端口改用非标端口)

  1. 端口伪装技巧

使用iptables重定向敏感端口:

iptables -t nat -A PREROUTING -p tcp --dport 2345 -j REDIRECT --to-port 22
  1. 定期审计策略

建议每周执行完整扫描并与基线对比

掌握端口检测技术只是安全防护的起点,真正的安全来自于持续监控、及时更新和分层防护策略的结合。通过本文的8种核心方法和3大进阶技巧,您已具备构建企业级端口管理体系的基础能力。记住:在网络安全领域,主动发现永远比被动响应更有价值。

附录:速查命令表

工具

命令示例

功能特点

netstat

netstat -tulnp

传统网络状态分析

ss

ss -tuln

高性能连接查看

nmap

nmap -sV -O 192.168.1.1

深度服务识别

lsof

lsof -i :80

进程级端口关联分析

ufw

ufw allow 443/tcp

Ubuntu防火墙管理

相关推荐

使用nginx配置域名及禁止直接通过IP访问网站

前段时间刚搭建好这个网站,一直没有关注一个问题,那就是IP地址也可以访问我的网站,今天就专门研究了一下nginx配置问题,争取把这个问题研究透彻。1.nginx配置域名及禁止直接通过IP访问先来看n...

如何在 Linux 中使用 PID 号查找进程名称?

在Linux的复杂世界中,进程是系统运行的核心,每个进程都由一个唯一的「进程ID」(PID)标识。无论是系统管理员在排查失控进程,还是开发者在调试应用程序,知道如何将PID映射到对应的进程名称都是一项...

Linux服务器硬件信息查询与日常运维命令总结

1.服务器硬件信息查询1.1CPU信息查询命令功能描述示例lscpu显示CPU架构、核心数、线程数等lscpucat/proc/cpuinfo详细CPU信息(型号、缓存、频率)cat/proc/c...

Ubuntu 操作系统常用命令详解(ubuntu常用的50个命令)

UbuntuLinux是一款流行的开源操作系统,广泛应用于服务器、开发、学习等场景。命令行是Ubuntu的灵魂,也是高效、稳定管理系统的利器。本文按照各大常用领域,详细总结Ubuntu必学...

从 0 到 1:打造基于 Linux 的私有 API 网关平台

在当今微服务架构盛行的时代,API网关作为服务入口和安全屏障,其重要性日益凸显。你是否想过,不依赖商业方案,完全基于开源组件,在Linux上构建一个属于自己的私有API网关平台?今天就带你...

Nginx搭建简单直播服务器(nginx 直播服务器搭建)

前言使用Nginx+Nginx-rtmp-module在Ubuntu中搭建简单的rtmp推流直播服务器。服务器环境Ubuntu16.04相关概念RTMP:RTMP协议是RealTi...

Linux连不上网?远程卡?这篇网络管理指南你不能错过!

大家好!今天咱们聊个所有Linux用户都躲不开的“老大难”——网络管理。我猜你肯定遇到过这些崩溃时刻:新装的Linux系统连不上Wi-Fi,急得直拍桌子;远程服务器SSH连不上,提示“Connecti...

7天从0到上线!手把手教你用Python Flask打造爆款Web服务

一、为什么全网开发者都在疯学Flask?在当今Web开发的战场,Flask就像一把“瑞士军刀”——轻量级架构让新手3天速成,灵活扩展能力又能支撑百万级用户项目!对比Django的“重型装甲”,Flas...

nginx配置文件详解(nginx反向代理配置详解)

Nginx是一个强大的免费开源的HTTP服务器和反向代理服务器。在Web开发项目中,nginx常用作为静态文件服务器处理静态文件,并负责将动态请求转发至应用服务器(如Django,Flask,et...

30 分钟搞定 Docker 安装与 Nginx 部署,轻松搭建高效 Web 服务

在云计算时代,利用容器技术快速部署应用已成为开发者必备技能。本文将手把手教你在阿里云轻量应用服务器上,通过Docker高效部署Nginx并发布静态网站,全程可视化操作,新手也能轻松上手!一、准...

Nginx 配置实战:从摸鱼到部署,手把手教你搞定生产级配置

各位摸鱼搭子们!今天咱不聊代码里的NullPointerException,改聊点「摸鱼必备生存技能」——Nginx配置!先灵魂拷问一下:写了一堆接口却不会部署?服务器被恶意请求打崩过?静态资源加载...

如何使用 Daphne + Nginx + supervisor部署 Django

前言:从Django3.0开始支持ASGI应用程序运行,使Django完全具有异步功能。Django目前已经更新到5.0,对异步支持也越来越好。但是,异步功能将仅对在ASGI下运行的应用程序可用...

Docker命令最全详解(39个最常用命令)

Docker是云原生的核心,也是大厂的必备技能,下面我就全面来详解Docker核心命令@mikechen本文作者:陈睿|mikechen文章来源:mikechen.cc一、Docker基本命令doc...

ubuntu中如何查看是否已经安装了nginx

在Ubuntu系统中,可以通过以下几种方法检查是否已安装Nginx:方法1:使用dpkg命令(适用于Debian/Ubuntu)bashdpkg-l|grepnginx输出...

OVN 概念与实践(德育概念的泛化在理论和实践中有什么弊端?)

今天我们来讲解OVN的概念和基础实践,要理解本篇博客的内容,需要前置学习:Linux网络设备-Bridge&VethPairLinux网络设备-Bridge详解OVS+Fa...

取消回复欢迎 发表评论: