如何通过Python脚本查找并终止占用指定端口的进程

简介: 在日常的开发和运维过程中,某些端口被意外占用是一个常见的问题。这种情况可能导致服务无法启动或冲突。本文将介绍如何通过Python脚本查找并终止占用指定端口的进程,以确保系统的正常运行。

在日常的开发和运维过程中,某些端口被意外占用是一个常见的问题。这种情况可能导致服务无法启动或冲突。本文将介绍如何通过Python脚本查找并终止占用指定端口的进程,以确保系统的正常运行。

环境准备

首先,我们需要安装psutil库,该库提供了一个跨平台的接口来方便地获取系统进程和系统利用率信息。可以使用以下命令安装psutil

pip install psutil

脚本实现

以下是完整的Python脚本,用于查找并终止占用指定端口的进程:

import psutil
import subprocess

def find_process_by_port(port):
    """通过端口查找进程"""
    for proc in psutil.process_iter(['pid', 'name', 'connections']):
        for conn in proc.info['connections']:
            if conn.laddr.port == port:
                return proc
    return None

def kill_process(proc):
    """终止进程"""
    subprocess.run(['taskkill', '/F', '/PID', str(proc.pid)])

# 检查端口9222是否被占用
port = 9222
process = find_process_by_port(port)

if process:
    print(f"端口 {port} 被进程 {process.info['name']} (PID {process.pid}) 占用。")
    kill_process(process)
    print(f"进程 {process.info['name']} (PID {process.pid}) 已被终止。")
else:
    print(f"端口 {port} 没有被占用。")

脚本解析

  1. 导入所需模块
import psutil
import subprocess
  1. 定义find_process_by_port函数: 该函数用于通过指定端口查找占用该端口的进程。它遍历系统中的所有进程,检查每个进程的连接信息,如果发现有进程占用了指定端口,则返回该进程对象。
def find_process_by_port(port):
    for proc in psutil.process_iter(['pid', 'name', 'connections']):
        for conn in proc.info['connections']:
            if conn.laddr.port == port:
                return proc
    return None
  1. 定义kill_process函数: 该函数用于终止指定的进程。它使用subprocess.run调用taskkill命令来强制终止进程。
def kill_process(proc):
    subprocess.run(['taskkill', '/F', '/PID', str(proc.pid)])
  1. 检查端口并终止进程: 检查端口9222是否被占用,如果被占用,则输出进程信息并终止该进程;否则,输出端口未被占用的信息。
port = 9222
process = find_process_by_port(port)

if process:
    print(f"端口 {port} 被进程 {process.info['name']} (PID {process.pid}) 占用。")
    kill_process(process)
    print(f"进程 {process.info['name']} (PID {process.pid}) 已被终止。")
else:
    print(f"端口 {port} 没有被占用。")

运行脚本

将上述脚本保存为一个Python文件(例如check_port.py),然后通过命令行运行:

python check_port.py

脚本将检查端口9222是否被占用,并根据结果执行相应的操作。

结论

通过上述方法,我们可以方便地查找并终止占用指定端口的进程。这在调试和维护系统时非常有用,能够帮助我们快速解决端口被占用的问题,从而保证服务的正常运行。此方法适用于Windows系统,若在其他操作系统上使用,需要调整kill_process函数中终止进程的命令。

相关文章
|
8天前
|
并行计算 数据处理 调度
Python中的并发编程:探索多线程与多进程的奥秘####
本文深入探讨了Python中并发编程的两种主要方式——多线程与多进程,通过对比分析它们的工作原理、适用场景及性能差异,揭示了在不同应用需求下如何合理选择并发模型。文章首先简述了并发编程的基本概念,随后详细阐述了Python中多线程与多进程的实现机制,包括GIL(全局解释器锁)对多线程的影响以及多进程的独立内存空间特性。最后,通过实例演示了如何在Python项目中有效利用多线程和多进程提升程序性能。 ####
|
7天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
28 2
|
9天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
24 3
|
14天前
|
缓存 运维 NoSQL
python常见运维脚本_Python运维常用脚本
python常见运维脚本_Python运维常用脚本
19 3
|
14天前
|
数据采集 JSON 数据安全/隐私保护
Python常用脚本集锦
Python常用脚本集锦
15 2
|
15天前
|
运维 监控 应用服务中间件
自动化运维:如何利用Python脚本提升工作效率
【10月更文挑战第30天】在快节奏的IT行业中,自动化运维已成为提升工作效率和减少人为错误的关键技术。本文将介绍如何使用Python编写简单的自动化脚本,以实现日常运维任务的自动化。通过实际案例,我们将展示如何用Python脚本简化服务器管理、批量配置更新以及监控系统性能等任务。文章不仅提供代码示例,还将深入探讨自动化运维背后的理念,帮助读者理解并应用这一技术来优化他们的工作流程。
|
16天前
|
运维 监控 Linux
自动化运维:如何利用Python脚本优化日常任务##
【10月更文挑战第29天】在现代IT运维中,自动化已成为提升效率、减少人为错误的关键技术。本文将介绍如何通过Python脚本来简化和自动化日常的运维任务,从而让运维人员能够专注于更高层次的工作。从备份管理到系统监控,再到日志分析,我们将一步步展示如何编写实用的Python脚本来处理这些任务。 ##
|
4月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
4月前
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
167 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
|
3月前
|
算法 Linux 调度
探索进程调度:Linux内核中的完全公平调度器
【8月更文挑战第2天】在操作系统的心脏——内核中,进程调度算法扮演着至关重要的角色。本文将深入探讨Linux内核中的完全公平调度器(Completely Fair Scheduler, CFS),一个旨在提供公平时间分配给所有进程的调度器。我们将通过代码示例,理解CFS如何管理运行队列、选择下一个运行进程以及如何对实时负载进行响应。文章将揭示CFS的设计哲学,并展示其如何在现代多任务计算环境中实现高效的资源分配。

热门文章

最新文章