游戏测试 Perfdog 实战之减少 CPU 消耗

不二 for 光娱游戏 · 2020年03月21日 · 最后由 gf 回复于 2020年12月10日 · 3592 次阅读

导语:
最近在测试过程中发现了一些比较典型的性能问题,所以来分享下作为测试怎么为解决问题提供更多的有效信息,本次主要从优化角度分析 Perfdog 测试报告。本次主要介绍关于 CPU 的优化;
怎么获取测试报告此处不再赘述,有关 perfdog 怎么使用的教程可以参考
Perfdog 使用教程

# 1. 第一部分,查找问题,找出问题特征点

首先我们看到 FPS 数据,可以看到 FPS 波动较大,但这是从某一时间开始的,在前期游戏 FPS 还是较为稳定的,那我们就要分析是什么原因导致的 FPS 开始变得不稳定;
在这里插入图片描述
我们发现CPU 的消耗在这个时间段开始骤然上升,CPU 的温度升高,导致手机的降频保护开启,CPU 的频率开始下降,
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# 2. 第二部分,分析报告后,得到分析结果

经过以上的数据分析,我们发现是游戏在那个时间点时 CPU 消耗上升,导致 CPU 的温度升高,处发了 CPU 的保护机制,引起 CPU 频率下降,而游戏得不到充足的算力支持,自然 FPS 变得不稳定;

# 3. 第三部分,得到分析结果,分析可以优化的空间

我们已经得知问题是 CPU 温度过高的问题,那么就要相应降低 CPU 的消耗,而 CPU 的消耗主要有以下几个方面(这里仅针对 Unity 引擎的,其他引擎仅供参考)

对于 MMORPG 手游:
CPU 的消耗可以从半透明渲染和不透明渲染入手解决;
可能有的同学会疑问,渲染通常都是 GPU 做的,和 CPU 有毛线的关系,这里要解答一下,
在安卓机器设计结果中目前大部分都是沿用的冯·诺依曼结构,也就是我们通常说的计算机的五大部件:
运算器、控制器、存储器、输入设备、输出设备, 而运算器、控制器组合就是 CPU,所以算力通常都是由 CPU 提供的,而如果不在游戏中另做设置的话,即使渲染也是由 CPU 提供的算力,而 GPU 就是为了减轻 CPU 的这种渲染压力而设计出来的一个部件,严格意义上来讲也属于运算器;
在这里插入图片描述
所以为了减轻压力,我们要把一些算力分给 GPU,减轻 CPU 的负担,而 unity 常用的手法有以下几种:
1.开启 GPU Instancing,降低 drawcall:
该技术可有效降低 Draw Call 的占用,从而对渲染模块的 CPU 端压力起到一定的缓解作用。但是,在使用该技术时,需要注意机型的测试,此技术仅可以用于 OpenGL ES 3.0,而且一些低端设备虽然支持 OpenGL ES 3.0,且 SystemInfo.supportsInstancing API 返回也为 True,但经过实际测试时,其底层并没有按照真实的 GPU Instancing 功能来进行渲染,而是通过逐个 Draw Call 来进行渲染,所以,虽然开启了 GPU Instancing 功能,但其渲染耗时并没有下降;
这里涉及到了 drawcall,简单介绍一下:
drawcall 是 CPU 对底层图形绘制接口的调用命令 GPU 执行渲染操作,一次渲染就是一个 Drawcall

渲染流程采用流水线实现,CPU 和 GPU 并行工作,它们之间通过命令缓冲区连接,CPU 向其中发送渲染命令,GPU 接收并执行对应的渲染命令,过多的 DrawCall 会造成 CPU 的性能瓶颈:大量时间消耗在 DrawCall 准备工作上。很显然的一个优化方向就是:尽量把小的 DrawCall 合并到一个大的 DrawCall 中,这就是批处理的思想,也就是 GPU Instancing 主要做的事情;
但要注意不要过于消耗 GPU,在开发游戏过程中随着 PBR、图像后处理的大量使用会导致 GPU 端的压力越来越大,甚至影响到了 CPU 端的 Draw Call 无法正常传输。可以说,主线程等待时间的体现方式因芯片的不同、具体使用情况的不同和引擎版本的不同,可谓是五花八门,在这里不一一进行说明,但归根原因主要还是 GPU 压力过大;
2.注意控制 GC 触发频率很
随着 MMORPG 游戏越来越重度化,GC 平均耗时在逐步上升,也会造成卡顿,大量的 GameObject 在频繁实例化和 Destroy 会造成很大的性能开销;
3.Shader.Parse
这里给出一些建议,
1)Shader 在游戏运行过程中是否存在冗余情况,即重复加载的情况;
2)是否有自定义的 Shader 资源放入到 Always Included 中,如有,请尽量去除;
3)移动端上 Standard Shader 的使用是否确实有必要。没有必要,则详细检测并删除。
4.动画模块
大量动画的产生会产生严重的开销,unity 引擎可以考虑使用 GPU Skinning 的方式进行优化,这种方式对于实现场景中的大量同种怪物非常有效,可以减少很多开销。其核心其实也是合批的思想;
5.粒子系统
这里建议尽可能将粒子使用数量峰值控制在 600 以下(低端设备)和 1000 以下(中高端设备),
可以检查下
1)粒子系统(特别是技能特效)的配置文件是否过量;
2)特效中是否含有长久不用的粒子系统。

以上是结合 Perfdog 的测试报告针对在游戏开发中 CPU 优化的一些常用手段,相信可以带来一些启发,大家可以根据自己的项目实际情况做参考;减少 CPU 的消耗,降低 CPU 的温度。

共收到 2 条回复 时间 点赞

这篇文章 相当有水平,有思路有方法

楼主对 unity 理解好深入

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册