《OpenACC并行程序设计:性能优化实践指南》一 3.5 在应用程序执行期间记录性能信息

简介: 本节书摘来自华章出版社《OpenACC并行程序设计:性能优化实践指南》一 书中的第3章,第3.5节,作者:[美] 罗布·法伯(Rob Farber),更多章节内容可以访问云栖社区“华章计算机”公众号查看。

3.5 在应用程序执行期间记录性能信息

应用程序将自动使用第一个插装事件启动Score-P性能监视器。使用几个环境变量来配置性能监视器。为了尽量减小运行时间扰动,Score-P默认设置产生一个基于性能分析的事件,这个事件不包含任何加速器活动。为了设置Score-P来记录PCIonGPU示例相关的活动,图3-5展示了与设置有关的环境变量。为了在Score-P 3.0版本中跟踪OpenACC API活动,将环境变量SCOREP_OPENACC_ENABLE设置为“yes”。Score-P文档中描述了其他可用的选项。

screenshot

程序执行完后,在当前工作目录下包含一个新的子文件夹,以scorep-<程序执行时间戳>命名。如图3-6所示,在这个文件夹里,可以找到分析(profile.cubex)和跟踪文件(trace.otf2)。

screenshot

生成的分析是了解应用程序行为的非常有价值的方法。对事件率未知或预期非常大的应用程序,建议开始仅生成分析,并扩展跟踪以覆盖所需的信息。这个需要通过限制插装或记录过滤来实现。查看“cube”文件可以可视化分析(profile.cubx),如图3-7所示。

screenshot

查看器显示了应用程序运行的多度量分析(最左列)。中间列显示的是最左列选中度量在程序函数间的情况。最右列显示的是中间列所选函数在应用程序运行期间的进程和线程情况。追踪文件允许对分析数据和时间上下文进行深入分析。如何使用它来优化PIConGPU应用参见以下章节。有关Score-P设置更详细说明参见安装手册。

相关文章
|
6月前
|
存储 SQL 运维
MSSQL性能调优精要:索引深度优化、查询高效重构与并发精细控制
在MSSQL数据库的运维与优化领域,性能调优是一项复杂而细致的工作,直接关系到数据库的稳定性和响应速度
|
6月前
|
缓存 自然语言处理 Java
浅析JAVA日志中的性能实践与原理解释问题之减少看得见的业务开销问题如何解决
浅析JAVA日志中的性能实践与原理解释问题之减少看得见的业务开销问题如何解决
|
6月前
|
存储 Java
浅析JAVA日志中的性能实践与原理解释问题之测试日志内容大小对系统性能的影响问题如何解决
浅析JAVA日志中的性能实践与原理解释问题之测试日志内容大小对系统性能的影响问题如何解决
130 0
|
8月前
|
缓存 Java Android开发
构建高效的Android应用:内存优化策略解析
【5月更文挑战第25天】在移动开发领域,性能优化一直是一个不断探讨和精进的课题。特别是对于资源受限的Android设备来说,合理的内存管理直接关系到应用的流畅度和用户体验。本文深入分析了Android内存管理的机制,并提出了几种实用的内存优化技巧。通过代码示例和实践案例,我们旨在帮助开发者识别和解决内存瓶颈,从而提升应用性能。
|
存储 Java 数据安全/隐私保护
项目实战典型案例15——高并发环境下由于使用全局变量导致数据混乱 高并发环境下对象被大量创建,导致GC并是CPU飙升
项目实战典型案例15——高并发环境下由于使用全局变量导致数据混乱 高并发环境下对象被大量创建,导致GC并是CPU飙升
181 0
项目实战典型案例15——高并发环境下由于使用全局变量导致数据混乱 高并发环境下对象被大量创建,导致GC并是CPU飙升
|
存储 消息中间件 Kafka
高效稳定的通用增量 Checkpoint 详解之二:性能分析评估
本文将从理论和实验两个部分详细论述通用增量 Checkpoint 的收益与开销,并分析其适用场景。
高效稳定的通用增量 Checkpoint 详解之二:性能分析评估
|
SQL 关系型数据库 API
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化(三)
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化(三)
|
SQL 存储 安全
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化(二)
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化
|
存储 C#
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化(一)
基于C#的ArcEngine二次开发37:循环查询过程的内存管理与性能优化
|
SQL 消息中间件 存储
一份平民化的应用性能优化检查列表(完整篇)
1.总原则 一些正确但稍显废话的原则,但能指导后面每个章节的优化,所以还是要啰嗦一次。 可扩展性架构,堆机器能不能解决问题是最最优先考虑的问题 去中心化的点对点通信,优于通过中心代理的通信 池化的长连接,优于短连接 二进制数据,优于文本数据 尽量减少交互,一次调用的粗粒度聚合接口 优于 多次调用的细粒度接口 尽量减少交互,批量接口优于循环调用 尽量只交互必要的数据 尽量就近访问 尽量使用缓存 总是设定超时 在合适的场景,并行化执行 在合适的场景,异步化执行 2.环境准备 保证符合自家各种规范(没有的话赶紧回家写一个),尤其线下压测服务器的配置要与生产环境一致。 2.1 操作系统 自家
148 0