- 内容提要
- 前言
- 作者简介
- 封面简介
- 第1章 理解高性能 Python
- 第2章 通过性能分析找到瓶颈
- 2.1 高效地分析性能
- 2.2 Julia 集合的介绍
- 2.3 计算完整的 Julia 集合
- 2.4 计时的简单方法——打印和修饰
- 2.5 用 UNIX 的 time 命令进行简单的计时
- 2.6 使用 cProfile 模块
- 2.7 用 runsnakerun 对 cProfile 的输出进行可视化
- 2.8 用 line_profiler 进行逐行分析
- 2.9 用 memory_profiler 诊断内存的用量
- 2.10 用 heapy 调查堆上的对象
- 2.11 用 dowser 实时画出变量的实例
- 2.12 用 dis 模块检查 CPython 字节码
- 2.13 在优化期间进行单元测试保持代码的正确性
- 2.14 确保性能分析成功的策略
- 2.15 小结
- 第3章 列表和元组
- 第4章 字典和集合
- 第5章 迭代器和生成器
- 第6章 矩阵和矢量计算
- 第7章 编译成 C
- 第8章 并发
- 第9章 multiprocessing 模块
- 第10章 集群和工作队列
- 第11章 使用更少的 RAM
- 第12章 现场教训
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
2.11 用 dowser 实时画出变量的实例
Robert Brewer的dowser可以在代码运行时钩入名字空间并通过CherryPy接口在一个Web服务器上提供一个实时的变量实例图。每个被追踪对象都有一个走势图,让你可以看到某个对象的数量是否在增长。这在分析长期运行的进程时很有用。
如果你有一个长期运行的进程且你预计程序的不同操作会带来不同的内存变化(比如你可能想对一台web服务器上传一些数据或跑一些复杂的查询),那么你可以实时确认这些变化,见图2-9。
要使用它,我们需要在Julia代码中加入辅助函数(例2-14)用来启动CherryPy服务器。
图2-9 dowser通过CherryPy显示的三张走势图
例2-14 在应用中启动dowser的辅助函数
def launch_memory_usage_server(port=8080): import cherrypy import dowser cherrypy.tree.mount(dowser.Root()) cherrypy.config.update({ 'environment': 'embedded', 'server.socket_port': port }) cherrypy.engine.start()
在开始计算之前,我们需要首先启动CherryPy服务器,如例2-15所示。完成计算后,我们可以调用time.sleep维持控制台打开——这会让CheeryPy进程保持运行,让我们可以继续审查名字空间的状态。
例2-15 在正确的时机启动dowser,这会启动一个Web服务器
... for xcoord in x: zs.append(complex(xcoord, ycoord)) cs.append(complex(c_real, c_imag)) launch_memory_usage_server() ... output = calculate_z_serial_purepython(max_iterations, zs, cs) ... print "now waiting..." while True: time.sleep(1)
点击图2-9中的TRACE链接,我们就可以看到每个list对象的内容(图2-10)。我们还可以继续深入每个list内部 ——这就像在IDE中使用一个交互调试器一样,但是你可以在一台服务器上进行而不需要一个IDE。
图2-10 dowser显示某个列表中有1 000 000个项目
备忘
我们当然更希望在可控的情况下直接分析代码块。但是有时这不一定做得到,或者有时你只是想要简单地分析一下情况。查看一个正在运行的进程的内部细节会是一种折中的方案,不需要进行太多的工作就可以提供足够的证据。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论