问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

GPU 利用率低常见原因分析及优化

发布网友 发布时间:2024-10-04 16:02

我来回答

1个回答

热心网友 时间:2024-11-12 14:38

一、GPU 利用率的定义


本文的 GPU 利用率主要指 GPU 在时间片上的利用率,即通过 nvidia-smi 显示的 GPU-util 这个指标。统计方式为:在采样周期内,GPU 上面有 kernel 执行的时间百分比。


二、GPU 利用率低的本质


常见 GPU 任务运行流程图如下:


如上图所示,GPU 任务会交替的使用 CPU 和 GPU 进行计算,当 CPU 计算成为瓶颈时,就会出现 GPU 等待的问题,GPU 空跑那利用率就低了。优化的方向就是缩短一切使用 CPU 计算环节的耗时,减少 CPU 计算对 GPU 的阻塞情况。


三、常见 GPU 利用率低原因分析



数据加载相关

1)存储和计算跨城了,跨城加载数据太慢导致 GPU 利用率低


说明:例如数据存储在“深圳 ceph”,但是 GPU 计算集群在“重庆”,那就涉及跨城使用了,影响很大。


优化:要么迁移数据,要么更换计算资源,确保存储及计算是同城的。



存储介质性能太差

说明:不同存储介质读写性能比较:本机 SSD > ceph > cfs-1.5 > hdfs > mdfs


优化:将数据先同步到本机 SSD,然后读本机 SSD 进行训练。本机 SSD 盘为“/dockerdata”,可先将其他介质下的数据同步到此盘下进行测试,排除存储介质的影响。



小文件太多,导致文件 io 耗时太长

说明:多个小文件不是连续的存储,读取会浪费很多时间在寻道上


优化:将数据打包成一个大的文件,比如将许多图片文件转成一个 hdf5/pth/lmdb/TFRecord 等大文件



未启用多进程并行读取数据

说明:未设置 num_workers 等参数或者设置的不合理,导致 cpu 性能没有跑起来,从而成为瓶颈,卡住 GPU


优化:设置 torch.utils.data.DataLoader 方法的 num_workers 参数、tf.data.TFRecordDataset 方法的 num_parallel_reads 参数或者 tf.data.Dataset.map 的 num_parallel_calls 参数。



未启用提前加载机制来实现 CPU 和 GPU 的并行

说明:未设置 prefetch_factor 等参数或者设置的不合理,导致 CPU 与 GPU 在时间上串行,CPU 运行时 GPU 利用率直接掉 0


优化:设置 torch.utils.data.DataLoader 方法的 prefetch_factor 参数 或者 tf.data.Dataset.prefetch()方法。prefetch_factor 表示每个 worker 提前加载的 sample 数量 (使用该参数需升级到 pytorch1.7 及以上),Dataset.prefetch()方法的参数 buffer_size 一般设置为:tf.data.experimental.AUTOTUNE,从而由 TensorFlow 自动选择合适的数值。



未设置共享内存 pin_memory

说明:未设置 torch.utils.data.DataLoader 方法的 pin_memory 或者设置成 False,则数据需从 CPU 传入到缓存 RAM 里面,再给传输到 GPU 上


优化:如果内存比较富裕,可以设置 pin_memory=True,直接将数据映射到 GPU 的相关内存块上,省掉一点数据传输时间



数据预处理相关

1)数据预处理逻辑太复杂


说明:数据预处理部分超过一个 for 循环的,都不应该和 GPU 训练部分放到一起


优化:a、设置 tf.data.Dataset.map 的 num_parallel_calls 参数,提高并行度,一般设置为 tf.data.experimental.AUTOTUNE,可让 TensorFlow 自动选择合适的数值。


b、将部分数据预处理步骤挪出训练任务,例如对图片的归一化等操作,提前开启一个 spark 分布式任务或者 cpu 任务处理好,再进行训练。


c、提前将预处理部分需要用到的配置文件等信息加载到内存中,不要每次计算的时候再去读取。


d、关于查询操作,多使用 dict 加速查询操作;减少 for、while 循环,降低预处理复杂度。



利用 GPU 进行数据预处理 -- Nvidia DALI

说明:Nvidia DALI 是一个专门用于加速数据预处理过程的库,既支持 GPU 又支持 CPU


优化:采用 DALI,将基于 CPU 的数据预处理流程改造成用 GPU 来计算



模型保存相关

1)模型保存太频繁


说明:模型保存为 CPU 操作,太频繁容易导致 GPU 等待


优化:减少保存模型(checkpoint)的频率



指标相关

1)loss 计算太复杂


说明:含有 for 循环的复杂 loss 计算,导致 CPU 计算时间太长从而阻塞 GPU


优化:该用低复杂度的 loss 或者使用多进程或多线程进行加速



指标上报太频繁

说明:指标上报操作太频繁,CPU 和 GPU 频繁切换导致 GPU 利用率低


优化:改成抽样上报,例如每 100 个 step 上报一次



日志相关

1)日志打印太频繁


说明:日志打印操作太频繁,CPU 和 GPU 频繁切换导致 GPU 利用率低


优化:改成抽样打印,例如每 100 个 step 打印一次



常见数据加载方法说明

1)pytorch 的 torch.utils.data.DataLoader


从参数定义中,我们可以看到 DataLoader 主要支持以下几个功能:


参考文档: pytorch.org/docs/stable...



tensorflow 的 tf.data.Dataset

参考文档: tensorflow.org/api_docs...



分布式任务常见的 GPU 利用率低问题

分布式任务相比单机任务多了一个机器间通信环节。如果在单机上面运行的好好的,扩展到多机后出现 GPU 利用率低,运行速度慢等问题,大概率是机器间通信时间太长导致的。请排查以下几点:



机器节点是否处在同一 modules?

答:机器节点处于不同 modules 时,多机间通信时间会长很多,deepspeed 组件已从平台层面增加调度到同一 modules 的策略,用户不需要操作;其他组件需联系我们开启。



多机时是否启用 GDRDMA?

答:能否启用 GDRDMA 和 NCCL 版本有关,经测试,使用 PyTorch1.7(自带 NCCL2.7.8)时,启动 GDRDMA 失败,和 Nvidia 的人沟通后确定是 NCCL 高版本的 bug,暂时使用的运行注入的方式来修复;使用 PyTorch1.6(自带 NCCL2.4.8)时,能够启用 GDRDMA。经测试,“NCCL2.4.8 + 启用 GDRDMA ” 比 “NCCL2.7.8 + 未启用 GDRDMA”提升 4%。通过设置 export NCCL_DEBUG=INFO,查看日志中是否出现[receive] via NET/IB/0/GDRDMA 和 [send] via NET/IB/0/GDRDMA,出现则说明启用 GDRDMA 成功,否则失败。



pytorch 数据并行是否采用 DistributedDataParallel ?

答:PyTorch 里的数据并行训练,涉及 nn.DataParallel (DP) 和nn.parallel.DistributedDataParallel (DDP) ,我们推荐使用 nn.parallel.DistributedDataParallel (DDP)。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
你家的水龙头起泡器该换了 如何打开水龙头起泡器 网上卖门锁,安装如何解决 广告装潢需要哪些设备 广告制作需要哪些材料 开锦旗招牌广告制做店须要什么 广告店需要哪些耗材 长安之星发动机水泵要坏之前声音怎么判断 家有孕妇咋调理:280天贴心呵护生健康宝贝图书信息 哪些是适合孕妇看的书 tensorflow如何用gpu训练? 我上个月在周六福买了个玉手镯,不透明的不知道是真的假的? 周六福玉手镯日常护理 iphone4删除桌面图标,抖动后没有叉叉,怎么办 , vivo x1s 的小挂件添加了却删除不掉 也找不到右上角的X怎么办... ...手机桌面上的图标怎么删除,按住也没有叉叉,也没有卸载,怎么办啊_百 ... 皇马球员名单及绰号 ...删除桌面图标? 我长按图标,它们也会跳动,但是没有一个小叉出现_百度... ...怎么在桌面上删除掉,我一直按到只是摇动了但是没有 步步高s6传统桌面上面的挂件怎么去掉?我添加了几个 很想删掉= =不会 注安师哪个科目难 2024年注册安全工程师考几科 数学应用题有哪三种类型? 浙江温州发邮政国内小包到东莞要几天? 我的被子衣服有25000克重浙江温州邮政快递寄到浙江台州要多少钱啊... 寄邮政包裹多少钱,我要从浙江温州寄到山东蓬莱,包裹大概有5斤重! 穿高领毛衣脖子会很痒为什么只是脖子氧 高中周记、、五百字以下的、 唱萨的网络解释唱萨的网络解释是什么 ...我指的是单位 同事之间 我平时性格内向 90年? 在深度学习训练中,什么是专用GPU内存与共享GPU内存的选择? 怎么看uber开源的基于mpi的分布式tensorflow训练框架horov tpu和gpu区别 王者荣耀皮肤实体礼品卡多少钱-皮肤实体礼品卡获取价格一览 ...中国移动A1S手机上用优酷下载的影片 , 一集影片会不会分成很多段短... 王者荣耀史诗礼品卡怎么获得 干海参怎样保存不变质 干海参保存不变质的方法介绍 干海参的保存方法及时间 我想要自己做一个可以放在自己拍的图片上的水印,不知到怎么设计,是不... 即停即走停多长时间算违章 ...了一个支付宝,再绑定了一个建设银行卡,现在已经换手机号了,换了手... 民用电和商用电价格有什么差距? 商用水商用电和民水民电的费用一样吗? ...老板叫新注册一个支付宝,解绑了银行卡和手机号,再把支付密码和支付宝... 我的支付宝注册了一个账号,手机号是我的身份证不是我的,我现在想要换一... 送男友的万圣节祝福短信 10kv,630kva的变压器一小时电耗多少度? 万圣节送男友什么礼物比较好 万圣节送男朋友什么 万圣节想给男友做糖。自己怎么做啊 托福作弊带模板的纸进去被抓,打完了考试,除了考试之前签的誓言,没让...