手机自动进程管理软件_进程管理器下载

手机自动进程管理软件_进程管理器下载大家好,我是小小明,今天要带大家做一款简易的网页版进程管理器,最终效果如下:目标只要求能查看内存使用何cpu使用率即可。基础模块技术测试读取进程信息首先,我们可以使用psutil读取服务端的进程使用情况(包括内存和CPU):importpsutiln=psutil.cpu_count()infos=[]forprocinpsutil.process_iter(attrs=[‘memory_info’,’name’,’pid’]):info=proc.in

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

大家好,我是小小明,今天要带大家做一款简易的网页版进程管理器,最终效果如下:

image-20210710003049714

目标只要求能查看内存使用何cpu使用率即可。

基础模块技术测试

读取进程信息

首先,我们可以使用psutil读取服务端的进程使用情况(包括内存和CPU):

import psutil

n = psutil.cpu_count()
infos = []
for proc in psutil.process_iter(attrs=['memory_info', 'name', 'pid']):
    info = proc.info
    memory_info = info['memory_info'].rss / 1024
    info['memory_info'] = memory_info
    cpu_percent = proc.cpu_percent(0) / n
    info['cpu_percent'] = f"{ 
     cpu_percent:.2f}%"
    infos.append(info)

然后我们可以按照内存使用量对数据进行降序排序:

infos.sort(key=lambda info: info['memory_info'], reverse=True)

然后可以对内存数据进行格式化(当然这步也可以交给游览器js来处理):

for info in infos:
    memory_info = info['memory_info']
    if memory_info < 1024:
        memory_info = f"{ 
     memory_info :.2f}KB"
    elif memory_info < 1024 * 1024:
        memory_info = f"{ 
     memory_info / 1024:.2f}MB"
    else:
        memory_info = f"{ 
     memory_info / 1024 / 1024:.2f}GB"
    info['memory_info'] = memory_info
return infos

杀掉某个进程

为了干掉某个进程,我们使用如下方法:

# 杀掉进程树
def kill_proc_tree(pid, sig=signal.SIGTERM, include_parent=True, timeout=None, on_terminate=None):
    if pid == os.getpid():
        raise RuntimeError("I refuse to kill myself")
    parent = psutil.Process(pid)
    children = parent.children(recursive=True)
    if include_parent:
        children.append(parent)
    for p in children:
        p.send_signal(sig)
    gone, alive = psutil.wait_procs(children, timeout=timeout, callback=on_terminate)
    return (gone, alive)

也可以调用系统命令:

def execute_cmd_command(PID):
    os.system("ntsd -c q -p PID".format(PID))

网页开发

基础前端模板

这次我们计划使用flask来开发一个小网站,所以使用jinja2模板的语法。

先做一个简单的前端页面(文件名show.html):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <title>进程列表</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.5.3/dist/css/bootstrap.min.css">
</head>
<body>
<div class="container">
    <h1>进程列表</h1>
    <table class="table">
        <thead>
        <tr>
            <th scope="col">排名</th>
            <th scope="col">pid</th>
            <th scope="col">name</th>
            <th scope="col">memory_info</th>
            <th scope="col">CPU使用率</th>
            <th scope="col">结束</th>
        </tr>
        </thead>
        <tbody>
        {% for row in data %}
            <tr>
                <td>{
  
  { loop.index }}</td>
                <td>{
  
  { row['pid'] }}</td>
                <td>{
  
  { row['name'] }}</td>
                <td>{
  
  { row['memory_info'] }}</td>
                <td>{
  
  { row['cpu_percent'] }}</td>
                <td><a href='/kill_proL/{ 
    { row['pid'] }}'>结束进程</a></td>
            </tr>
        {% endfor %}
        </tbody>
    </table>
</div>
</body>
</html>

jinja2模板语法的规则可以百度。

完善后端代码:

""" 小小明的代码 CSDN主页:https://blog.csdn.net/as604049322 """
__author__ = '小小明'
__time__ = '2021/7/9 22:21'

import psutil
from flask import Flask, redirect, render_template
import os
import signal

app = Flask(__name__)


# 获取系统进程列表
def get_procs():
    infos = []
    n = psutil.cpu_count()
    for proc in psutil.process_iter(attrs=['memory_info', 'name', 'pid']):
        info = proc.info
        memory_info = info['memory_info'].rss / 1024
        info['memory_info'] = memory_info
        cpu_percent = proc.cpu_percent(0) / n
        info['cpu_percent'] = f"{ 
     cpu_percent:.2f}%"
        infos.append(info)
    infos.sort(key=lambda info: info['memory_info'], reverse=True)
    for info in infos:
        memory_info = info['memory_info']
        if memory_info < 1024:
            memory_info = f"{ 
     memory_info :.2f}KB"
        elif memory_info < 1024 * 1024:
            memory_info = f"{ 
     memory_info / 1024:.2f}MB"
        else:
            memory_info = f"{ 
     memory_info / 1024 / 1024:.2f}GB"
        info['memory_info'] = memory_info
    return infos


# 杀掉进程树
def kill_proc_tree(pid, sig=signal.SIGTERM, include_parent=True, timeout=None, on_terminate=None):
    if pid == os.getpid():
        raise RuntimeError("I refuse to kill myself")
    parent = psutil.Process(pid)
    children = parent.children(recursive=True)
    if include_parent:
        children.append(parent)
    for p in children:
        p.send_signal(sig)
    gone, alive = psutil.wait_procs(children, timeout=timeout, callback=on_terminate)
    return (gone, alive)


def execute_cmd_command(PID):
    os.system("ntsd -c q -p PID".format(PID))


@app.route('/kill_proL/<pid>', methods=['GET'])
def kill_proL(pid):
    try:
        kill_proc_tree(int(pid))
        # execute_cmd_command(pid)
    finally:
        return redirect("/")  # 重新加载页面


@app.route('/')
def Show_html():
    data = get_procs()
    return render_template('show.html', data=data)


if __name__ == "__main__":
    app.run(host="0.0.0.0", port=8888)

注意:show.html需要方法上述py脚本的同级templates目录下。

咱们运行看看效果:

image-20210710005140057

比较粗糙但是可以用。

升级版前端开发

这次我们计划给表头增加排序和筛选的功能。

经过一番开发,编译出了仿Excel的筛选功能的JavaScript脚本和css样式表:

image-20210710005401112

对于index.html模板的代码为:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>服务端进程列表</title>
    <link href="../static/css/bootstrap.min.css" rel="stylesheet">
    <link rel="stylesheet" type="text/css" href="../static/css/demo.css">
    <link rel="stylesheet" href="../static/dist/excel-bootstrap-table-filter-style.css"/>

</head>
<body>

<div class="container">
    <div class="row">
        <div class="col-md-12">
            <h2>进程列表</h2>
            <table id="table" class="table table-bordered table-intel">
                <thead>
                <tr>
                    <th class="filter">排名</th>
                    <th class="filter">pid</th>
                    <th class="filter">name</th>
                    <th class="filter">memory_info</th>
                    <th class="no-filter">CPU使用率</th>
                    <th class="no-sort no-filter">结束</th>
                </tr>
                </thead>
                <tbody>
                { 
   % for row in data %}
                    <tr>
                        <td>{ 
   { 
    loop.index }}</td>
                        <td>{ 
   { 
    row['pid'] }}</td>
                        <td>{ 
   { 
    row['name'] }}</td>
                        <td>{ 
   { 
    row['memory_info'] }}</td>
                        <td>{ 
   { 
    row['cpu_percent'] }}</td>
                        <td><a href='/kill_proL/{ 
   { row['pid'] }}'>结束进程</a></td>
                    </tr>
                { 
   % endfor %}
                </tbody>
            </table>
        </div>
    </div>
</div>

<script type="text/javascript" src="../static/js/jquery-1.11.0.min.js"></script>
<script type="text/javascript" src="../static/dist/excel-bootstrap-table-filter-bundle.js"></script>
<script type="text/javascript">
    $(function () { 
   
        $('#table').excelTableFilter({ 
   
            'captions': { 
   a_to_z: '升序排列', z_to_a: '降序排列', search: '搜索', select_all: '全部选择'}
        });
        $('#table2').excelTableFilter({ 
   
            'captions': { 
   a_to_z: '升序排列', z_to_a: '降序排列', search: '搜索', select_all: '全部选择'}
        });
        $('#table3').excelTableFilter({ 
   
            'captions': { 
   a_to_z: '升序排列', z_to_a: '降序排列', search: '搜索', select_all: '全部选择'}
        });
    });
</script>

</body>
</html>

于是就可以在前端按CPU使用率来排序了:

image-20210710005728811

还可以筛选筛选包含指定名称的进程:

image-20210710005828082

测试结束进程可以顺利的关闭服务器上面的金山词霸、钉钉等非系统进程。

至此我们就成功的完成了网页版进程管理器的开发。

前端代码获取方式

本文评论数过20并且阅读量达到1000以上,或者将本文转发到自己的朋友圈,可向作者索要本文全套代码的下载地址。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/195114.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 好博客[通俗易懂]

    好博客[通俗易懂]Elar的博客 http://www.cnblogs.com/elaron/peghoty的博客 http://blog.csdn.net/itplus/article/details/10484553炼数成金         http://f.dataguru.cn/thread-339602-1-1.htmlverydemo    http://www.verydemo.

  • s一般怎么称呼自己的m_男人一般都这样称呼自己的情人?

    s一般怎么称呼自己的m_男人一般都这样称呼自己的情人?阅读本文前,请您先点击上面的“蓝色字体”,再点击“关注”,这样您就可以继续免费收到文章了。每天都会有分享,都是免费订阅,请您放心关注。注:本文转载自网络,不代表本平台立场,仅供读者参考,著作权属归原创者所有。我们分享此文出于传播更多资讯之目的。如有侵权,请在后台留言联系我们进行删除,谢谢!…

  • Python——因子分析(KMO检验和Bartlett’s球形检验)「建议收藏」

    Python——因子分析(KMO检验和Bartlett’s球形检验)「建议收藏」因子分析用Python做的一个典型例子一、实验目的采用合适的数据分析方法对下面的题进行解答二、实验要求采用因子分析方法,根据48位应聘者的15项指标得分,选出6名最优秀的应聘者。三、代码importpandasaspdimportnumpyasnpimportmathasmathimportnumpyasnpfromnumpyimpor…

  • POJ 3207 Ikki&#39;s Story IV – Panda&#39;s Trick (2-SAT)

    POJ 3207 Ikki&#39;s Story IV – Panda&#39;s Trick (2-SAT)

  • 自定义bt服务器,[教程]Aria2自动更新BT Tracker服务器列表的方法[通俗易懂]

    自定义bt服务器,[教程]Aria2自动更新BT Tracker服务器列表的方法[通俗易懂]说明公开的BTtracker服务器,因为种种原因总会经常失效,要想获取更多的peer需要经常维护这份列表。感谢github上的小伙伴提供了这么一份tracker自动更新列表:trackerslist。我们要想Aria2也支持自动更新这份列表,那么你可以按照下面方法来实现。方法此文仅适用于Centos系统,其它系统稍作变更即可。我没有使用过其它系统,这里也就不提供兼容性的脚本了。示例:Aria2安…

  • cap的原理_圣维南原理的应用举例

    cap的原理_圣维南原理的应用举例在分布式系统中,有一个基本原则叫做CAP,consistence,一致性,availability,可用性,partitiontolerance分区容错性。一致性,在这里指的是分布式系统的各个副本

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号