我试图在服务器上的替代端口下安装站点,但端口可能被防火墙关闭。是否有一种方法可以ping出或ping入一个特定的端口,以查看它是否打开?


当前回答

在Windows机器上,您可以使用Microsoft的PortQry来检查应用程序是否已经在侦听特定端口,使用以下命令:

portqry -n 11.22.33.44 -p tcp -e 80

其他回答

如果你想查看Windows服务器上所有被使用和监听的端口,使用这个:

netstat -an |find /i "listening"

查看所有开放、监听、已建立的端口:

netstat -a

在Windows机器上,您可以使用Microsoft的PortQry来检查应用程序是否已经在侦听特定端口,使用以下命令:

portqry -n 11.22.33.44 -p tcp -e 80

如果你从外部检查,而不是从服务器本身检查,并且你不想安装telnet(因为它没有随最新版本的Windows提供)或任何其他软件,那么你有原生的PowerShell:

Test-NetConnection -Port 800 -ComputerName 192.168.0.1 -InformationLevel Detailed

(不幸的是,这只适用于PowerShell 4.0或更新版本。要检查PowerShell版本,输入$PSVersionTable。)

PS:注意,这些天在twitter上有一些声明,暗示这个答案可以通过提到PowerShell Core中的“Test-Connection”或快捷键“tnc”来改进。请参阅https://twitter.com/david_obrien/status/1214082339203993600并帮助我编辑这个答案以改进它!


(如果你的PSVersion < 4.0,你就不走运了。查看这个表格:

尽管你可以通过安装Windows管理框架4.0来升级你的PowerShell版本,但它对我来说并没有什么用,Test-NetConnection cmdlet仍然不可用)。

在Windows服务器上可以使用

netstat -an | where{$_.Contains("Yourport")}

我喜欢这样:

netstat -an | find "8080" 

从远程登录

telnet 192.168.100.132 8080

确保那台机器的防火墙已经关闭。