根据port端口号查找process进程(服务)或者根据服务名字查找端口号

首先介绍根据服务名字查找端口:

控制面板->管理工具->服务,比如已经开启的服务mysql5_pn,右键属性,可以查看到它的服务名字,显示名字,和对应的进程exe,我们平时在cmd中的命令net start service之类的命令这个service就是服务名字,而tasklist命令查找的是进程名字,这时候我们找到mysql5_pn对应的进程名字是mysqld-nt,然后使用tasklist |findstr mysqld-nt,就会列出对应的信息,我们找到pid,比如说是3372,然后敲netstat -aon |findstr 3372,然后就会列出含有3372字符串的一些进程,同时显示了端口,这样就从一个服务名字来获得它的端口号了。

在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但往往很多时候只需要查看某个端口的使用情况,它到底被那个进程(对应PID)占用了,或者你还需要把它Kill掉。如果你在Windows操作系统,你可以使用netstat命令来查询PID,然后可以打开任务管理器,查看这个PID对应的进程名;如果PID没有显示,菜单》查看》选择列》选中PID即可;得知进程后,我们可以将进程杀掉。下面我简单描述一下我所了解的在Windows和Linux系统下处理方式。 (假如我们需要确定谁占用了我们的9010端口)

1、Windows平台
在windows控制台窗口下执行:
netstat -nao | findstr "9010"
TCP 127.0.0.1:9010 0.0.0.0:0 LISTENING 3017

你看到是PID为3017的进程占用了9010端口,如果进一步你想知道它的进程名称,你可以使用如下命令:

tasklist | findstr "3017"

如果你想杀死这个进程,你当然可以用前面描述的那种方法,在任务管理器里把它KILL了,但如果你喜欢高效一点,那么用taskkill命令就可以了。

taskkill /pid 3017

那么这个进程就灰灰湮灭了:)

2、Linux

如果你是个Linux爱好者,那个这个命令你应该很熟了,

netstat -pan | grep 9010

如果你稍微仔细一点,你会发现,用的都是netsta命令,事实上,netstat是一个比较通用的网络统计命令,几乎适用于所有现在流行的操作系统,无论是Linux,Window,还是其他Unix,或者Unix-like操作系统,而且用法基本一致。

下面是一个对Windows系统中netstat命令行参数的详细解释。

格式:

netstat [-a] [-e] [-n] [-o] [-p Protocol] [-b] [-r] [-s] [-v] [Interval]

参数说明:

-a 显示所有连接和监听端口。
-n 以数字形式显示地址和端口号。

-o 显示与每个连接相关的所属进程 ID。

-p 在Windows系统中,该选项用于指定默认情况的子集。proto 显示 proto 指定的协议的连接;proto 可以是下列协议之一: TCP、UDP、TCPv6 或 UDPv6。

如果与 -s 选项一起使用以显示按协议统计信息,proto 可以是下列协议之一:
IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 或 UDPv6。


-b 显示包含于创建每个连接或监听端口的可执行组件。在某些情况下已知可执行组件拥有多个独立组件,并且在这些情况下; 包含于创建连接或监听端口的组件序列被显示。这种情况下,可执行组件名在底部的 [] 中,顶部是其调用的组件,等等,直到 TCP/IP 部分。注意此选项
可能需要很长时间,如果没有足够权限可能失败。

-e 显示以太网统计信息。此选项可以与 -s选项组合使用。


-s 显示按协议统计信息。默认地,显示 IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 和 UDPv6 的统计信息。

-r 显示路由表。

-v 与 -b 选项一起使用时将显示包含于为所有可执行组件创建连接或监听端口的组件。

interval 重新显示选定统计信息,每次显示之间暂停时间间隔(以秒计)。按 CTRL+C 停止重新显示统计信息。如果省略,netstat 显示当前
配置信息(只显示一次)。

以下是使用 C# 编写的一个简单的窗口工具,可以根据端口号自动查找进程映像名: ```csharp using System; using System.Diagnostics; using System.Linq; using System.Windows.Forms; namespace PortToProcessTool { public partial class MainForm : Form { public MainForm() { InitializeComponent(); } private void btnSearch_Click(object sender, EventArgs e) { if (int.TryParse(txtPort.Text.Trim(), out int port)) { var processes = Process.GetProcesses().Where(p => p.PortIsListening(port)).ToList(); if (processes.Any()) { var processNames = processes.Select(p => p.ProcessName).Distinct().ToList(); txtResult.Text = string.Join(Environment.NewLine, processNames); } else { txtResult.Text = "No process is listening on port " + port; } } else { MessageBox.Show("Invalid port number", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } } } public static class ProcessExtensions { public static bool PortIsListening(this Process process, int port) { var connections = IPGlobalProperties.GetIPGlobalProperties().GetActiveTcpConnections(); return connections.Any(c => c.State == TcpState.Established && c.LocalEndPoint.Port == port && c.ProcessId == process.Id); } } } ``` 在窗口上放置一个 `TextBox` 控件(用于输入端口号)、一个 `Button` 控件(用于触发查找操作)和一个 `TextBox` 控件(用于显示查找结果),然后在相应的事件处理程序中调用 `Process.GetProcesses()` 方法获取所有正在运行的进程,然后筛选出监听指定端口的进程,最后将结果显示在 `TextBox` 控件中即可。为了方便使用,我们还可以将上述操作封装到一个扩展方法 `PortIsListening()` 中,以便在 LINQ 查询中使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值