在windows操作系统中,查询端口占用和清除端口占用的程序

在windows操作系统中,查询端口占用和清除端口占用的程序

一、在windows操作系统中,查询端口占用和清除端口占用的程序

提升权限后用:netstat -b
或用

1、查询端口占用的进程ID

         点击"开始"-->"运行",输入"cmd"后点击确定按钮,进入DOS窗口,接下来分别运行以下命令:
netstat -a -n  各个端口占用
netstat -ano   各个端口占用和进程PID
         netstat -aon | findstr "80"
     C:\Users\admin>netstat -aon|findstr "80"
  TCP    127.0.0.1:9080         0.0.0.0:0              LISTENING       4632

2、查看端口号所对应的应用程序
       tasklist | findstr "  4632"

      补充: tasklist /fi "pid eq 4632"
GROOVE.EXE 4632 Console 1 84,880 K
很明显,是GROOVE.EXE 占用了80端口,GROOVE.EXE 一个IE的ACTIVEX控件。

3、终止进程
        taskkill /pid 4632 /F
     或则使用 taskkill /f /t /im GROOVE.exe

再次查询是否成功终止
    tasklist | findstr "4632"
如果成功终止此次执行命令后应返回空.,则表示成功,终止 PID 为 4632 的进程。

二、在Linux操作系统中,查询端口占用和清除端口占用的程序

1、查询端口号占用,根据端口查看进程信息

[root@server2 ~]# lsof -i:80
COMMAND  PID   USER   FD   TYPE DEVICE SIZE NODE NAME
httpd   5014   root    3u  IPv4  14346       TCP server2:http (LISTEN)
2、根据进程号查看进程对应的可执行程序
ps -f -p 进程号
# ps -f -p 5014
UID        PID  PPID  C STIME TTY          TIME CMD
root      5014     1  0 17:26 ?        00:00:00 /usr/local/apache/bin/httpd -k
3、根据可执行程序查看动态链接
ldd 可执行文件名

ldd  /usr/local/apache/bin/httpd
        linux-vdso.so.1 =>  (0x00007fff9dc90000)
        libaprutil-0.so.0 => /usr/local/apache/lib/libaprutil-0.so.0 (0x00002af026fcd000)  
4、根据端口号得到其占用的进程的详细信息

netstat -tlnp|grep 80
tcp        0      0 192.168.33.10:80            0.0.0.0:*                   LISTEN      5014/httpd
tcp        0      0 0.0.0.0:48054               0.0.0.0:*                   LISTEN      5386/java

这一步骤等于刚才上面的一二两个步骤

5、根据端口号查询,查询其占用进程ID

netstat -tlnp|grep 80|awk '{print $7}'|awk -F '/' '{print $1}'
5014
或则是用下面的命令

netstat -pan|grep 80

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

-e            显示以太网统计信息。此选项可以与 -s选项组合使用。                
-n            以数字形式显示地址和端口号。
-o            显示与每个连接相关的所属进程 ID。
-p proto      显示 proto 指定的协议的连接;proto 可以是下列协议之一: TCP、UDP、TCPv6 或 UDPv6。  如果与 -s 选项一起使用以显示按协议统计信息,proto 可以是下列协议之一: IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 或 UDPv6。                
-r   显示路由表。
-s  显示按协议统计信息。默认地,显示 IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 和 UDPv6 的统计信息;
-p 选项用于指定默认情况的子集。                
-v            与 -b 选项一起使用时将显示包含于 为所有可执行组件创建连接或监听端口的组件。                
interval      重新显示选定统计信息,每次显示之间 暂停时间间隔(以秒计)。按 CTRL+C 停止重新 显示统计信息。如果省略,netstat 显示当前 配置信息(只显示一次)

6、一次性的清除占用80端口的程序

lsof -i :80|grep -v "PID"|awk '{print "kill -9",$2}'|sh

7、手工终止进程的运行

kill 5014
如果终止不了,可以强制终止
kill -9 5014
lsof -i:80    

应该就不会查询出被占用的进程了

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows服务器的ntoskrnl.exe是操作系统内核的一部分,负责处理系统的各种核心功能。ntoskrnl.exe本身并不直接占用网络端口,而是由其他进程通过网络占用端口。 在Windows服务器上,443端口通常用于HTTPS协议,用于安全的Web浏览和传输数据。ntoskrnl.exe占用443端口的情况可能是由于以下几种原因: 1. IIS服务:ntoskrnl.exe是IIS(Internet Information Services)的一部分,IIS是Windows服务器上的Web服务器软件。如果在服务器上安装了IIS并且启用了HTTPS服务,ntoskrnl.exe就会作为Web服务器的一部分占用443端口。 2. 其他应用程序:某些应用程序可能会使用ntoskrnl.exe来进行网络通信,从而占用443端口。这可能是自定义的应用程序或者第三方应用程序,需要通过查看系统运行的进程或者网络连接来确定占用443端口的具体应用程序。 3. 恶意软件:一些恶意软件可能会伪装成ntoskrnl.exe来占用443端口,以便在系统执行恶意活动。在这种情况下,建议进行杀毒软件的全面扫描以查找和清除恶意软件。 为了解决ntoskrnl.exe占用443端口的问题,可以尝试以下方法: 1. 检查IIS设置:如果使用IIS作为Web服务器,请确保HTTPS服务的配置正确。可以查看IIS管理界面来确认是否有使用443端口的网站,并检查它们的设置。 2. 查找占用443端口的应用程序:使用任务管理器或者其他系统监控工具来查看系统运行的进程和网络连接,找出占用443端口的具体应用程序,并采取相应的措施。 3. 更新和运行杀毒软件:确保系统上安装了最新的安全更新,并运行杀毒软件进行全面扫描,以查找和清除可能存在的恶意软件。 通过以上方法可以解决ntoskrnl.exe占用443端口的问题,并确保服务器的正常运行。如果问题持续存在,建议咨询专业的系统管理员或者技术支持人员。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值