

Linux 中如何检查开放的端口
source link: https://www.51cto.com/article/721948.html
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Linux 中如何检查开放的端口

无论你的服务器是用的Linux还是桌面系统,了解系统开放的端口,和正在使用的端口,在各种情况下都会有所帮助。
比如,如果你的服务器中正在运行着 Apache或者Nginx,那么其端口应该为80或者443,可以检查一下。再比如你可以检查一下 SMTP、SSH或者其他服务用的是哪个端口。当有新的服务需要开放端口的时候,你需要知道目前已经被占用的,都有哪些端口。
此外,可以检查一下是否有开放的可用于入侵检测的端口。
Linux 中有多种检查端口的方法,本文将介绍两种。
使用 lsof 检查当前系统开放的端口
不管你是直接登录的系统,还是使用 ssh 连接的,都可以使用 lsof 命令来检查端口:
sudo lsof -i -P -n
该命令用于查找用户使用的文件和进程。上述命令中的选项,包括:
- -i: 如果没有指定IP地址,那么此选项就会选择所有网络文件的列表;
- -P: 禁止将网络文件的端口号转换为端口名;
- -n: 禁止将网络文件的网络编号转为主机名。

但是,这也会展示许多计算机并没有监听的其他端口。
我们可以通过管道将此输出传输到 grep,并匹配模式 “LISTEN”,如下所示:
sudo lsof -i -P -n | grep LISTEN
这样就只显示计算机正在监听的,以及正在运行的服务所占用的端口。
使用 netcat 命令检查远程服务器上的端口
nc(Netcat) 是一个命令行实用程序,使用TCP和UDP协议在网络计算机之间读取和写入数据。
以下是nc命令的语法:
nc [options] host port
这个工具有一个很实用的 -z 选项,它会让 nc 命令扫描正在监听的守护进程,但是不会向端口发送任何数据。
将其与 -v 选项结合,启动详细信息,会有详细信息的输出。
如下是使用 nc 命令扫描开放的端口:
nc -z -v 1-65535 2>&1 | grep -v 'Connection refused'
将上面的 替换为你要检查的 Linux 系统的IP地址。
至于为什么我会选择 1 到 65535,那是因为端口的范围是 1 到 65535。
最后,通过管道将输出传到grep,使用 -v 选项可以排除“拒绝连接( Connection refused)”的端口。
这样就会扫描到计算机上所有开放的端口,这些端口可以被网络上的其他机器访问。
以上两种方法中,lsof 比 nc 速度要快。但是使用 lsof 需要先登录到系统中,并且具有 sudo 访问权限。所以,如果你扫描的是你已经登录到的系统,可以优先选择 lsof。
nc 命令可以很灵活的扫描端口,而不需要登录。
以上就是本次分享的全部内容,欢迎讨论。
Recommend
-
129
开放Azure虚拟机端口,Azure虚拟机端口映射
-
191
[root@i-hnx0tx7t ~]# nmap -sU 127.0.0.1 -p68 -PnStarting Nmap 6.40 ( http://nmap.org ) at 2018-03-04 19:46 CST...
-
23
最近,我们就同一主题写了两篇文章。这些文章内容帮助你如何检查远程服务器中给定的端口是否打开。 如果你想
-
40
Amazon Web Services - @luaer - 自己机子用 firewalld 是确定已经开放自己想开放的端口入站规则也配了相应的 TCP 端口 最后甚至都配所有 TCP 端口都没用天哪这鬼东西为什么这么难用 气死了
-
8
穆世明博客 技术分享 ...
-
7
V2EX › Android Vivo 手机某系统进程开放 55555 端口疑似用作 mCDN droidmax61 · 1 小时...
-
11
7 May 2021 / linux #Linux 如何检查远程端口是否打开 使用nc命令可以检查远程端口是否打开,用来判断连接是否可用。 nc -zv <...
-
7
Linux 如何查看端口占用、开放情况-51CTO.COM Linux 如何查看端口占用、开放情况 作者:木偶跳舞 2022-04-05 14:13:56 哪个端口被哪个服务占用?有多少个开放端口?本文介绍如何扫描 Linux 系...
-
9
测试端口是否开放可以用专业的端口扫描工具,但是如果没有太多要求,完全可以用几个简易的命令行来测试。 另外博主自己也写了一个Android应用,开源绿色,文末会给出下载地址。 TCP端口测试 由于TCP是面向连接的协议,所以判断TCP端口是否开放...
-
9
Linux 下指定端口开放访问权限 作者:Grey 原文地址: ...
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK