【问题标题】:Command line for looking at specific port用于查看特定端口的命令行
【发布时间】:2012-08-14 04:30:26
【问题描述】:

有没有办法从 Windows 命令行检查特定端口的状态?我知道我可以使用 netstat 检查所有端口,但 netstat 很慢,而且查看特定端口可能不是。

【问题讨论】:

  • netstat 只有在不使用 -n 开关时才会慢,这意味着它必须进行大量 DNS 查找。

标签: windows networking port command-prompt


【解决方案1】:

它将为您提供特定 IP 上的所有活动套接字:

netstat -an | find "172.20.1.166"

【讨论】:

    【解决方案2】:

    在 RHEL 7 中,我使用此命令过滤处于 LISTEN 状态的几个端口:

    sudo netstat -tulpn | grep LISTEN | egrep '(8080 |8082 |8083 | etc )'
    

    【讨论】:

      【解决方案3】:

      这对你有帮助

      netstat -atn | grep <port no>          # For tcp
      netstat -aun | grep <port no>           # For udp
      netstat -atun | grep <port no>          # For both
      

      【讨论】:

        【解决方案4】:

        这是寻找端口的简单解决方案...

        在cmd中:

        netstat -na | find "8080"
        

        在 bash 中:

        netstat -na | grep "8080"
        

        在 PowerShell 中:

        netstat -na | Select-String "8080"
        

        【讨论】:

        • 这个命令怎么用?我想知道这个端口号是否有效链接:- [链接]( https://.localhost:9043/ibm/console/login.do)
        • 另外值得一提的是-o标志(即-nao这里)包括使用端口的进程的PID。
        【解决方案5】:
        netstat -a -n | find /c "10.240.199.9:8080"
        

        它将为您提供特定 IP 和端口(服务器端口号)上活动的套接字数量

        【讨论】:

        • 这不适用于 windows 2012 R2 上的 windows power shell,收到的结果为 FIND: Parameter format not correct
        【解决方案6】:

        对于 80 端口,命令为:netstat -an |找到“80” 对于端口 n,命令为:netstat -an |找到“n”

        这里,netstat 是你机器的指令

        -a : 显示所有连接和监听端口 -n :以数字格式显示所有地址和指令(这是必需的,因为 -a 的输出可以包含机器名称)

        然后,一个查找命令来“模式匹配”前一个命令的输出。

        【讨论】:

          【解决方案7】:

          我用:

          netstat –aon | find "<port number>"
          

          这里的o代表进程ID。 现在您可以对进程 ID 进行任何操作。 要终止进程,例如,使用:

          taskkill /F /pid <process ID>
          

          【讨论】:

            【解决方案8】:

            改进@EndUzr's response

            要查找外部端口(IPv4 或 IPv6),您可以使用:

            netstat -an | findstr /r /c:":N [^:]*$"
            

            要查找本地端口(IPv4 或 IPv6),您可以使用:

            netstat -an | findstr /r /c:":N *[^ ]*:[^ ]* "
            

            其中 N 是您感兴趣的端口号。“/r”开关告诉它以正则表达式处理它。 "/c" 开关允许 findstr 在搜索字符串中包含空格,而不是将空格视为搜索字符串分隔符。这个增加的空间可以防止更长的端口被滥用 - 例如,“:80”与“:8080”以及其他端口转换问题。

            列出到本地 RDP 服务器的远程连接,例如:

            netstat -an | findstr /r /c:":3389 *[^ ]*:[^ ]*"
            

            或者查看谁在访问您的 DNS:

            netstat -an | findstr /r /c:":53 *[^ ]*:[^ ]*"
            

            如果您想排除仅限本地的端口,您可以使用一系列带有“/v”的异常并使用反斜杠转义字符:

            netstat -an | findstr /v "0.0.0.0 127.0.0.1 \[::\] \[::1\] \*\:\*" | findstr /r /c:":80 *[^ ]*:[^ ]*"
            

            【讨论】:

              【解决方案9】:

              使用 lsof 命令“lsof -i tcp:port #”,这里是一个例子。

              $ lsof -i tcp:1555 
              COMMAND   PID USER   FD   TYPE   DEVICE SIZE/OFF NODE NAME
              java    27330 john  121u  IPv4 36028819      0t0  TCP 10.10.10.1:58615->10.10.10.10:livelan (ESTABLISHED)
              java    27330 john  201u  IPv4 36018833      0t0  TCP 10.10.10.1:58586->10.10.10.10:livelan (ESTABLISHED)
              java    27330 john  264u  IPv4 36020018      0t0  TCP 10.10.10.1:58598->10.10.10.10:livelan (ESTABLISHED)
              java    27330 john  312u  IPv4 36058194      0t0  TCP 10.10.10.1:58826->10.10.10.10:livelan (ESTABLISHED)
              

              【讨论】:

              • 减分,因为这不是 Windows 命令。如果它在 Windows 上可用,则没有关于如何获取它的讨论。
              • 不回答 OP 的问题。 -1.
              【解决方案10】:

              对于 Windows 8 用户:打开命令提示符,键入 netstat -an |找到“你的端口号”,输入 .

              如果回复类似于LISTENING,那么端口正在使用中,否则它是空闲的。

              【讨论】:

                【解决方案11】:

                如其他地方所述:使用带有适当开关的 netstat,然后使用 find[str] 过滤结果

                最基本的:

                netstat -an | find ":N"
                

                netstat -a -n | find ":N"
                

                要查找您可以使用的外国端口:

                netstat -an | findstr ":N[^:]*$"
                

                要查找您可能使用的本地端口:

                netstat -an | findstr ":N.*:[^:]*$"
                

                其中 N 是您感兴趣的端口号。

                -n 确保所有端口都是数字的,即不返回为翻译成服务名称。

                -a 将确保您搜索所有连接(TCP、UDP、监听...)

                find 字符串中,您必须包含冒号作为端口限定符,否则该数字可能与本地或外国地址匹配。

                您可以根据需要使用其他 netstat 开关进一步缩小搜索范围...

                延伸阅读 (^0^)

                netstat /?
                
                find /?
                
                findstr /?
                

                【讨论】:

                  【解决方案12】:

                  此命令将显示所有端口及其目标地址:

                  netstat -f 
                  

                  【讨论】:

                  • 请求是查明一个特定的端口是否正在使用中。
                  【解决方案13】:

                  当我遇到 WAMP apache 问题时,我使用此代码查找正在使用端口 80 的程序。

                  netstat -o -n -a | findstr 0.0:80
                  

                  3068 是 PID,所以我可以从任务管理器中找到它并停止该进程。

                  【讨论】:

                  • 非常好,非常感谢!特别是对于 TCP,我使用以下命令:netstat -o -nap TCP | findstr 0.0:80
                  【解决方案14】:

                  您可以将netstat-np 标志和findfindstr 命令的管道结合使用。

                  基本用法如下:

                  netstat -np <protocol> | find "port #"
                  

                  例如要检查 TCP 上的 80 端口,您可以这样做:netstat -np TCP | find "80" 最终给出以下类型的输出:

                  TCP    192.168.0.105:50466    64.34.119.101:80       ESTABLISHED
                  TCP    192.168.0.105:50496    64.34.119.101:80       ESTABLISHED
                  

                  如您所见,这仅显示 TCP 协议端口 80 上的连接。

                  【讨论】:

                    猜你喜欢
                    • 2016-09-26
                    • 2021-05-30
                    • 1970-01-01
                    • 1970-01-01
                    • 1970-01-01
                    • 1970-01-01
                    • 1970-01-01
                    • 1970-01-01
                    相关资源
                    最近更新 更多