Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python运行时动态查看进程内部信息

Python运行时动态查看进程内部信息

作者头像
kongxx
发布于 2018-05-14 06:12:49
发布于 2018-05-14 06:12:49
2.1K00
代码可运行
举报
运行总次数:0
代码可运行

接前两篇“运行时查看线程信息”的博客,我在想,既然我可以随时打印线程信息,那么我是不是可以随时打印进程内部的其它信息呢?比如,实时查看一些对象属性等,这样可以帮助我们在不重新启动应用程序的情况下就可以观察进程的执行状态。(这里暂时不考虑那些使用第三方库或工具的情况)

根据这个想法,查看了一下python的动态加载模块的方法,感觉这个想法还是比较靠谱,应该可以实现,所以动手写了个小测试验证了一把。(这里说明一下,只是验证性的,生产环境要使用的话,还是有不少问题需要考虑的。)

下面就是测试时考虑要做到的

  • 还是使用 SIGQUIT 信号即“kill -3”来触发执行打印进程内部对象属性.
  • foo.py主程序,包括注册信号处理函数,创建一个全局的对象用来保存一些属性,启动一个线程让主线程不退出。
  • foo.py主程序中的信号处理函数动态加载一个指定路径的下的模块,这里我们就假定这个模块路径是"/tmp/my_modules",可以根据需要修改。然后调用这个模块中的方法来打印一些进程信息。
  • /tmp/my_modules/bar.py需要动态加载的模块,其中访问foo模块中的一个对象,并打印对象属性。
  • 要能随时动态修改要查看的进程状态,即在不重启进程的情况下,通过修改bar.py文件修改要实现查看的内容。

主程序 foo.py

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/usr/bin/env /usr/bin/python3.4
# -*- coding: utf-8 -*-
import sys
import threading
import signal
from datetime import datetime
import time


class MyObject(object):
    def __init__(self):
        self.data = {}
        self.data['a'] = 'aaa'
        self.data['b'] = 'bbb'
        self.data['c'] = 'ccc'


def test():
    while True:
        print(datetime.now())
        time.sleep(2)

# 信号处理函数
def signal_handler(signum, frame):
    try:
        # 动态加载模块
        sys.path.append("/tmp/my_modules")

        # 导入bar模块
        bar = __import__('bar')

        # 重新加载模块,为的是可以随时重新加载模块
        reload(bar)

        # 调用动态加载模块的方法
        bar.execute()
    except BaseException as e:
        print(e)


my_object = MyObject()

if __name__ == "__main__":
    try:
        signal.signal(signal.SIGQUIT, signal_handler)

        threading.Thread(target=test).start()

        while True:
            time.sleep(60)
    except KeyboardInterrupt:
        sys.exit(1)

需要动态加载的模块 /tmp/my_modules/bar.py

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/usr/bin/env /usr/bin/python3.4
# -*- coding: utf-8 -*-
import foo


def execute():
    # 打印foo模块中的对象
    print "my_object: %s " % foo.my_object.data

测试

首先运行foo.py

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ python foo.py

然后找到foo.py的进程号,然后使用“kill -3”来触发打印内存对象的方法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ kill -3 <pid>

此时应该可以看到foo.py进程打印my_object的属性。

修改一下 /tmp/my_modules/bar.py 文件,然后再次运行“$ kill -3 <pid>”,可以看到模块被重新加载了,然后打印的新的内容。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.04.25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Python中的小魔法(二)
01 函数 局部变量 x = 66 def func(x): print('x等于', x) x = 6 print('局部变量x改变为', x) func(x) print('x一直是', x) 结果 x等于66 局部变量x改变为6 x一直是66 使用全局声明 x = 66 def func(): global x print('x的值是', x) x = 6 print('全局变量x改为', x) func() print('x的值是',
小歪
2018/04/04
6920
Python3运行时查看线程信息
前一篇文章说了一下在是用Python2的情况下怎样查看运行时线程信息,今天查资料的时候发现,原来在Python3中引入了 faulthandler 模块,可以简化我们很多工作,甚至,如果不需要保持进程继续运行的情况下可以不用修改我们已有的代码。具体 faulthandler 模块的使用,可以参考: faulthandler https://docs.python.org/3/library/faulthandler.html 先准备一个小程序,就是周期性的往命令行终端输出一下时间,如下: #!/usr
kongxx
2018/05/14
2.1K0
Python2运行时查看线程信息
今天遇见一个 Python 问题,在测试环境中发现用 Python2.7.10 写的程序有时候会慢慢变慢,在使用 "pstack <pid>" 查看进程的时候发现起了很多的线程,并且越来越多,这肯定是程序有问题,但是使用 pstack 命令看不到具体每个线程是在做什么,于是我就想是不是可以在不影响进程运行的情况下随时查看每个线程都在干什么。 于是乎,我大致想了一下 可以使用 signal 模块在处理程序接收 kill 信号,这样我就可以使用 “kill -3 <pid>” 来给进程发信号,然后输出线程信息而
kongxx
2018/05/14
9090
Python中熟悉而又陌生的 if __name__ == "__main__"
在 python 文件中,我们经常会看到 if __name__ == "__main__" 。那么 if __name__ == "__main__" 是什么?它可以用来干什么呢?下面就来详细解释下。
mr.songw
2021/01/14
7800
Python中熟悉而又陌生的 if __name__ == "__main__"
Python学习笔记_Day03
读取任何文件都可以用bytes方式打开。读取文件内容时,如果是文本内容,将会以字符的形式显示,如果不能转成字符,将会直接显示16进制数。
非著名运维
2022/06/22
4200
Xmake v2.9.1 发布,新增 native lua 模块和鸿蒙系统支持
它使用 xmake.lua 维护项目构建,相比 makefile/CMakeLists.txt,配置语法更加简洁直观,对新手非常友好,短时间内就能快速入门,能够让用户把更多的精力集中在实际的项目开发上。
ruki
2024/04/25
2611
Xmake v2.9.1 发布,新增 native lua 模块和鸿蒙系统支持
python基于函数替换的热更新原理介绍
热更新即在不重启进程或者不离开Python interpreter的情况下使得被编辑之后的python源码能够直接生效并按照预期被执行新代码。平常开发中,热更能极大提高程序开发和调试的效率,在修复线上bug中更是扮演重要的角色。但是要想实现一个理想可靠的热更模块又非常的困难。
py3study
2020/01/19
2.6K0
python 学习笔记day02-pyt
            语句 while_suite 会被连续不断的循环执行,直到表达式的值变成 0 或 False
py3study
2020/01/14
4850
Python炫技操作:模块重载的五种方法
由于有 sys.modules 的存在,当你导入一个已导入的模块时,实际上是没有效果的。
AI科技大本营
2020/10/27
5100
Python炫技操作:模块重载的五种方法
Signal 信号量使用详解 | Python基础
信号定义? linux中信号被用来进行进程间的通信和异步处理,简单地可以理解会为回调函数,当发送一个信号时,触发相应的操作。 signal是python中用来处理信号的模块,主要针对UNIX类平台,比
程序员荒生
2022/03/04
2.3K0
使用信号进制实现进程通信
而在应用系统开发中,我们常用的方式就是消息队列和套接字两种方式。在程序中写了一个死循环,运行时,常使用 ctrl+c来中断进程。突然软件卡死了,我们无法关闭,这时,你知道使用kill -9 pip来结束进程。这些基本的操作常识性操作,背后就使用的“信号量"和应用程序发生通信。
暮雨
2019/08/21
7380
使用信号进制实现进程通信
而在应用系统开发中,我们常用的方式就是消息队列和套接字两种方式。在程序中写了一个死循环,运行时,常使用<code>ctrl+c</code>来中断进程。突然软件卡死了,我们无法关闭,这时,你知道使用kill -9 pip来结束进程。这些基本的操作常识性操作,背后就使用的“信号量"和应用程序发生通信。
暮雨
2019/08/19
1.1K0
秒啊!Python 信号量源码拆解来了!
在类Unix系统上,信号用于将各种信息发送到正在运行的进程,它们来自用户命令,其他进程以及内核本身。所以信号是对已发生事件进程的通知,也可以被描述为软件中断,因为在大多数情况下,它们会中断程序的正常执行流程。
程序员荒生
2022/03/04
1.1K0
秒啊!Python 信号量源码拆解来了!
Python模块的交叉引用(导入循环)问题分析
    首先交叉引用或是相互引用,实际上就是导入循环,关于导入循环的详细说明,可见我摘自《python核心编程》第二版的摘抄:Python导入循环方法。
党志强
2020/02/11
5.5K0
JavaScript 中 10 个需要掌握基础的问题
JavaScript 是一种客户端编程语言。 全球超过90%的网站都在使用它,它是世界上最常用的编程语言之一。 因此,今天我们业讨论 10 个有关 JavaScript 的常见问题。
前端小智@大迁世界
2020/10/23
2.8K0
Python中动态创建类实例
简介 在Java中我们可以通过反射来根据类名创建类实例,那么在Python我们怎么实现类似功能呢? 其实在Python有一个builtin函数import,我们可以使用这个函数来在运行时动态加载一些模块。如下: def createInstance(module_name, class_name, *args, **kwargs): module_meta = __import__(module_name, globals(), locals(), [class_name]) class_m
kongxx
2018/05/14
2.6K0
解决python3中关于import的疑难杂症
在Python工程项目中,如果一个文件夹下有__init__.py文件就会认为该文件夹是一个包package,这样可以方便组织工程文件,避免模块名冲突。
TOMOCAT
2021/04/09
1.9K0
Python程序员最常犯的十个错误
来源:编程派 不管是在学习还是工作过程中,人都会犯错。虽然Python的语法简单、灵活,但也一样存在一些不小的坑,一不小心,初学者和资深Python程序员都有可能会栽跟头。本文是Toptal网站的
编程范 源代码公司
2018/04/16
9970
Python程序员最常犯的十个错误
编程语言中的变量作用域与闭包
如果你写过 javascript,应该听说过变量提升(hoisting),如果你自诩“Life is short, I use Python”,那么多多少少会用过global、nonlocal这两个关键字。无论新手还是老手,遇到这些时都会觉得很别扭,稍不留神就会出现意想不到的 bug,如果你仔细观察就会发现,它们其实是一个问题:变量作用域的问题。
飞驰的西瓜
2022/07/26
5470
编程语言中的变量作用域与闭包
Linux驱动实践:驱动程序如何发送【信号】给应用程序?
大家好,我是道哥,今天我为大伙儿解说的技术知识点是:【驱动层中,如何发送信号给应用程序】。
IOT物联网小镇
2021/12/09
2.9K0
Linux驱动实践:驱动程序如何发送【信号】给应用程序?
相关推荐
Python中的小魔法(二)
更多 >
领券
💥开发者 MCP广场重磅上线!
精选全网热门MCP server,让你的AI更好用 🚀
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验