tensorflow释放显存

本文探讨了在Tensorflow中释放GPU显存的两种方法:使用numba库的cuda模块直接控制CUDA清理显存,以及利用multiprocessing的Process特性在进程结束后自动释放资源。后者可在释放GPU显存后重新开启session,更为实用。

经过测试,通过sess.close释放资源并不能释放显存,导致重新建立一个session分配资源时失败。

stackoverflow上提到了两种方法:

1.利用numba库(需要安装numba库)

背后原理:
Tensorflow只是为GPU分配显存,而CUDA负责管理GPU内存。
如果在用sess.close()清除了所有图形后,CUDA以某种方式拒绝释放GPU显存,那么您可以使用cuda库直接控制CUDA以清除GPU显存。

from numba import cuda

def train():
    .
    .
    .


train()
cuda.select_device(0) # 选择GPU设备
cuda.close() # 释放GPU资源

缺点:
以这种方式清除GPU显存会存在问题,再次开启session时会失败,原因貌似是cuda.close破坏了tensorflow开启session的环境。

from numba import cuda

def train():
    .
    .
    .


train()
cuda.select_device(0) # 选择GPU设备
cuda.close() # 释放GPU资源
train() # 失败(抛出异常)

2.利用multiprocessing的Process

背后原理:
进程结束后会自动释放和进程相关的资源,这就好比模型训练完成退出程序后会自动释放显存。

from multiprocessing import Process

def train():
    .
    .
    .

if __name__'__main__': # 在windows必须在这句话下面开启多进程
    p = Process(target=train)
    p.start()
    p.join() # 进程结束后,GPU显存会自动释放
    p = Process(target=train) # 重新训练
    p.start()
    p.join()

优点:
相比第一种方法,可以在释放GPU显存后重新开启session。

参考资料:
stackoverflow

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值