记录一次内存泄漏的修复过程

1、现象

通过Flask API请求调用一个实例的方法,加载pysparnn的索引,每次调用都增加800M,怀疑内存泄漏。

2 、工具

memory_profiler,    pympler

momery_profiler 使用:

这样每次调用的话,可以知道每一行代码调用是否增加了内存。

from memory_profiler import profile

@profile
def obj_fun():
    print('here')
    """
     this is your function code
     """

pympler的使用:

from pympler import tracker,summary,muppy
memory_tracker = tracker.SummaryTracker()

# 在你运行完你的方法后使用这一句代码
memory_tracker.print_diff()

如果有内存泄漏,那么结果是一些dict,list大于零。

3、结论:

python 用pickle保存对象和加载对象,貌似这会内存泄漏,其实不会泄漏。

最后结论是用pickle导入对象时候,是第三方库泄漏的内存。

泄漏内存的元凶,是第三方库(pysparnn)的变量循环引用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ai君臣

学会的就要教给人

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值