tracemalloc分析内存使用情况与泄露
admin
2024-03-04 02:09:18
0

tracemalloc分析内存使用情况与泄露

1.概述

python内存管理是通过引用计数执行的,如果指向某个对象的引用全部过期,那么受引用的对象就可以从内存中清除,从而给其他数据腾出空间。理论上讲,python开发不用担心程序如何分配和释放内存,因为python系统本身以及Cpython运行环境会自动处理这些问题。
但实际情况程序会因为没有及时释放不再需要引用的数据耗尽内存。下面通过一些方法来看下内存使用情况。

2.查看gc引用对象总数

下面是被测试代码,这个代码可以创建对象,在gc中产生引用对象。

import osclass MyObject:def __init__(self):self.data = os.urandom(100)def get_data():values = []for _ in range(100):obj = MyObject()values.append(obj)return valuesdef run():deep_values = []for _ in range(100):deep_values.append(get_data())return

下面的代码用来输出当前gc引用对象的数量

import gc# 获取运行前gc引用对象数量
found_objects = gc.get_objects()
print('Before:', len(found_objects))# 导入待测试模块
import waste_memory# 运行待测试代码的函数
hold_reference = waste_memory.run()# 获取运行代码后gc引用对象数量
found_objects = gc.get_objects()
print('After: ', len(found_objects))
for obj in found_objects[:5]:print(repr(obj)[:100])print('...')

运行上面的代码,下面是gc引用的对象总数。

Before: 28834
After:  28923

3.tracemalloc查看内存分配情况

3.1.查看内存分配情况

上面只输出了gc的总数,对于分析内存分配情况没有太多的指导意义,tracemalloc模块能够追溯到分配它的位置,因此我们可以在之前模块前后对内存使用情况做个快照,分析两个快照之间的区别。

下面是被测试代码

import tracemalloctracemalloc.start(10)                      # Set stack depth
time1 = tracemalloc.take_snapshot()        # Before snapshotimport waste_memoryx = waste_memory.run()                     # Usage to debug
time2 = tracemalloc.take_snapshot()        # After snapshotstats = time2.compare_to(time1, 'lineno')  # Compare snapshots
for stat in stats[:3]:print(stat)

运行上面的代码,从结果中可以看出,每一条记录都有size与count指标,用来表示这行代码所分配的对象占用多少内存,以及对象的数量。通过对比就能发现占用内存较多的对象是由那几行代码分配的。

/waste_memory.py:11: size=5120 B (+5120 B), count=80 (+80), average=64 B
/waste_memory.py:14: size=4424 B (+4424 B), count=79 (+79), average=56 B
/waste_memory.py:9: size=1704 B (+1704 B), count=8 (+8), average=213 B

3.2.查看栈信息

tracemalloc还可以打印栈的追踪信息,下面把程序中分配内存最多的那行代码所对应的栈追踪信息打印出来,看看程序是沿着哪条路径触发这行代码的。


import tracemalloctracemalloc.start(10)
time1 = tracemalloc.take_snapshot()import waste_memoryx = waste_memory.run()
time2 = tracemalloc.take_snapshot()stats = time2.compare_to(time1, 'traceback')
top = stats[0]
print('Biggest offender is:')
# 打印栈信息
print('\n'.join(top.traceback.format()))

运行上面的代码

Biggest offender is:File "/with_trace.py", line 14x = waste_memory.run()File "/waste_memory.py", line 23deep_values.append(get_data())File "/waste_memory.py", line 16obj = MyObject()File "/waste_memory.py", line 11self.data = os.urandom(100)

相关内容

热门资讯

金价又崩了!5月这波下跌,藏着... 昨天看行情的时候,我一度以为自己眼花了。 5月18日亚市早盘,现货黄金伦敦金直接失守4500美元/盎...
拿下百年药企、进军医院市场,广... (本文作者为 牛刀财经NiuDaoCJ,钛媒体经授权发布) 文 | 牛刀财经NiuDaoCJ ...
一心卖车的蔚来,终于被看懂了 作者 | 定焦One 陈颐 中国资本市场对新能源汽车的态度,最近一年发生了转变。 具身智能、飞行汽...
原创 杨... 赚的不多,拿的不少。 作者 | 于婞 编辑丨高岩 来源 | 野马财经 与明星爱人黄圣依再见1年后,“...
历史首次!东莞A股上市公司,市... 据东莞市上市公司协会消息,截至2026年5月15日收盘,东莞64家A股上市公司总市值首次突破万亿元,...
对标行业龙头先导智能,格林晟港... 在锂电制造的中段——从极片到电芯成型的核心环节,有一项设备至关重要:叠片机,它直接决定了电池的能量密...
银行存款大局已定?明后年,存款... 银行存款的大局,已经从“怎么多赚点利息”,变成了“怎么少亏点、别踩坑”。 2025年以来,存款利率一...
巨佬们最新重仓股来了! 管理规模超10亿美金的全球投资大师最新业绩来了! (本文内容均为客观数据信息罗列,不构成任何投资建...
一文读懂Token经济学新模式 AI应用的商业化,正在从卖软件、卖会员,延伸到卖Token调用能力。这里的Token,是大模型处理信...
原创 欧... 近年来,欧洲的欧洲的处境一直难言轻松,尤其是到了今年,许多本可缓解的问题突然集中爆发,让现实的压力一...
合肥国资,把很多地方国资都给带... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 长鑫科技更新了招股书,业绩...
A股新“股王”,提示风险 截至5月18日收盘,联讯仪器股价为1344.99元/股,总市值约1381亿元。 联讯仪器称,公司于2...
ETF复盘资讯|硬科技强者恒强... 5月18日,A股低开后冲高回落,三大指数盘中一度集体翻红,午后再度下行,为连续第3日调整。截至收盘,...
中东混乱推动比特币大涨20%,... 据日经中文网报道,资金正在流入代表性虚拟货币比特币。自美国开始攻击伊朗的2月底至今,比特币的涨幅达到...
央行上海总部:4月末境外机构持... 观点网讯:5月18日,人民银行上海总部发布《2026年4月份境外机构投资银行间债券市场简报》显示,截...
马斯克花 100 亿想清楚一件... 1. OpenAI 的两大宿敌 Anthropic 和马斯克,放下心中成见之后终于在月初结盟了。 ...
标普全球评级亚太区首席经济学家... “AI(人工智能)不仅是一个‘金融故事’,它已经是一个‘实体经济故事’。美国正在建设大量数据中心,每...
国家统计局:1—4月份国民经济... 今天上午,国务院新闻办召开新闻发布会,国家统计局新闻发言人表示,今年1—4月份,我国有效实施更加积极...
AI时代,全球光电子产业迎来“... AI时代,全球光电子产业迎来“光谷时刻” ——第二十一届“中国光谷”国际光电子博览会今日开幕 往...
“我真的撑不住了”,2000万... 5月14日、15日两天,知名搞笑博主“大连老湿王博文”,分别在微信公众号和小红书上发表长文,宣布断更...