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

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

ahcoder 2025-03-23 16:58 15 浏览

在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防火墙管理

相关推荐

ARM64内核内存布局图(ARM64内核内存布局图解)

ARM64架构处理器采用48位物理寻址机制,最大可以寻找到256TB的物理地址空间。对于目前的应用来说已经足够了,不需要扩展到64位的物理地址寻址。虚拟地址也同样最大支持48位支持,所以在处理器的架构...

ARM64 linux 调试串口通信(ARM64 linux 调试串口通信实验报告)

ARM64linux调试串口通信随着国产机普及很多工作也转移到了新平台上,以前调试设备用的笔记本电脑也换成新国产ARM64架构的了。本文以绿联CM204USB-A转RJ45Console调试线...

Gentoo Linux 终止对 Itanium IA-64 体系的支持

GentooLinux是最后几个继续维护Itanium(IA-64)架构构建的Linux发行版之一,但现在这些已停产的英特尔处理器正在逐步淘汰。由于Linux6.7内核放弃了对Itan...

如何检查 Linux 系统是 32 位还是 64 位?这9个命令查的又快又准!

在Linux系统中,位数(bit)通常指的是CPU架构的位宽,即CPU一次能够处理的数据量。32位系统和64位系统在内存寻址能力、计算性能和软件支持上存在显著差异:「32位系统」:...

调出好画面!带你玩转飞凌嵌入式AM62x开发板的显示接口

来源:飞凌嵌入式官网“显示”是嵌入式开发板最为重要的功能之一,能够支持更多种类、更高规格的显示接口,意味着它能够应对的使用场景也更加广泛。每一款嵌入式开发板在出厂前都会做屏幕调试,但在客户的实际项目开...

带你玩转AM62x开发板的显示接口——LVDS的显示和修改方式

此前小编已为大家介绍过OK6254-C开发板的RGB显示和修改方式,今天将继续为大家介绍OK6254-C开发板的LVDS显示和修改方式。话不多说,我们进入正题。1、LVDS接口规格飞凌嵌入式OK62...

AM335x继任者?AM6254性能解析(am2361p)

飞凌嵌入式FET6254-C核心板基于TISitaraTMAM62x系列工业级处理器设计开发,采用ARMCortex-A53架构,主频最高可达1.4GHz;并集成了丰富的接口,可广泛应用于的工...

如何在 Linux 发行版中安装微信和 QQ?

很多人因为工作沟通的原因需要用到微信和QQ,那么如何在Linux发行版中安装微信和QQ呢?以下是一些尝试的解决方法。QQ上一个版本的QQLinux版还是在2009年,而在现在,基于N...

MySQL:物理备份工具XBK(mysql 备份方案)

XBK的优缺点:XBK(PerconaXtraBackup)优点:1.免费2.热备:备份期间不阻塞innodb和XtraDB表,但会阻塞Myisam表3.物理备份:备份恢复快XBK缺点:1.不支持远...

AMD锐龙9 9950X CPU AIDA64跑分曝光:比7950X最高快45%

IT之家6月26日消息,Anandtech论坛网友igor_kavinski本周一发布帖子,分享了AMD旗舰锐龙99950X处理器的AIDA64基准测试跑分,与当前基于Z...

qemu linux内核(5.10.209)开发环境搭建

版本信息宿主机:ubuntu20.04.6LTS(FocalFossa)虚拟机:ubuntu20.04.6LTS(FocalFossa)安装宿主机的步骤省略,和一般的在vmware中安...

iPhone 7成刷机神器,成功运行乌班图、Linux、安卓

在智能机刚开始流行的时候,很多手机发烧友都喜欢刷机,当时民间大神们制作了特别多优化的ROM。后来随着手机硬件的逐步提升,以及厂商们对系统的大力优化,让大家对于刷机的兴趣也越来越少。不知道大家还记得这部...

12 款最佳免费开源 Linux 渲染器 | 火狐浏览器 130.0 版本更新

12款最佳免费开源Linux渲染器Linux的一大优势在于其拥有丰富的开源软件,可以满足艺术家、摄影师、动画师和设计师的需求。凭借价格低廉的硬件、免费的软件以及少量的才能和灵感,任何人都可以创...

Linux中xargs 命令详解与实用场景

xargs是Linux系统中常用的命令行工具之一,它能够从标准输入构造参数列表并传递给其他命令使用,是处理批量数据操作时的重要利器。一、xargs的基本语法xargs[OPTION]...[C...

Linux 磁盘扩容(非LVM)方式(linux扩容lvm磁盘容量)

今天接到一个客户的需求,CentOS的/分区容量太小了,OA系统所有的数据都在这下面,由于当时前同事给客户安装系统时采用了标准分区,而不是LVM逻辑卷,所以不支持在线扩容。df-hT查看磁盘使...