ldd gperftool 用法

2024-06-02 11:18
文章标签 用法 ldd gperftool

本文主要是介绍ldd gperftool 用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


1.ldd 用来显示进程所依赖的动态库路径

[root@iZ94xjteonrZ C++]# ldd test
        linux-vdso.so.1 =>  (0x00007fff8cb08000)
        libprofiler.so.0 => /usr/local/lib/libprofiler.so.0 (0x00007fb1f0d6a000)
        libunwind.so.8 => not found
        libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fb1f0b4c000)
        libc.so.6 => /lib64/libc.so.6 (0x00007fb1f07b9000)
        libunwind.so.7 => not found
        libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00007fb1f04b2000)
        libm.so.6 => /lib64/libm.so.6 (0x00007fb1f022e000)
        libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007fb1f0018000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fb1f0f83000)
[root@iZ94xjteonrZ C++]# 


export LD_LIBRARY_PATH 的使用 用来设置环境变量  设置共享库的搜索位置


2.

1. 下载libunwind (wget http://download.savannah.gnu.org/releases/libunwind/libunwind-1.1.tar.gz)

    mkdir ../libunwind

    ./configure prefix=/home/tools/libunwind

    make  && make install


2. 下载 gperftools (wget http://code.google.com/p/gperftools/downloads/list/gperftools-2.0.tar.gz

    mkdir ../gperftools 

   ./configure prefix=/home/tools/gperftools --enable-frame-pointers

    make  && make install

 


 

3. export LD_LIBRARY_PATH=/home/tools/gperftools/lib

    export PATH=$PATH:/home/tools/gperftools/bin

 

4. mkdir ../test && cd ../test

    vi test.cpp

#include <google/profiler.h>
#include <iostream>
using namespace std;
void test1() 

{
    int i = 0;
    while (i < 1000) 

     {
        i++;
    }  
}

void test2() 
{

    int i = 0;
    while (i < 2000)  

   {
        i++;
    }  
}


void test3() 

 {
    for (int i = 0; i < 100000; ++i) 
    {
        test1();
        test2();
    }  
}


int main()

 {
    ProfilerStart("test.prof"); // test.prof is the name of profile file
     test3();
    printf("Finish!");
    ProfilerStop(); 
    return 0;
}

 

5. 编译

   g++ -o test test.cpp -I /home/tools/gperftools/include -I /home/tools/libunwind/include -L/home/tools/gperftools/lib/ -lprofiler  -L/home/tools/libunwind/lib/ -lunwind

 

6. ./test

生成test.prof文件

 

7. pprof --text test test.prof

输出:

 Using local file test.
Using local file test.prof.
Total: 100 samples
      59  59.0%  59.0%       59  59.0% test2
      40  40.0%  99.0%       40  40.0% test1
       1   1.0% 100.0%        1   1.0% test3

官方文档:http://code.google.com/p/google-perftools/wiki/GooglePerformanceTools


分析输出

pprof脚本用于分析profile文件并输出结果,包括文本和图形两种输出风格。

例如:demo是目标程序,my.prof是profile文件

生成文本风格结果:pprof --text ./demo my.prof > profile.txt

生成图形风格结果:pprof --pdf ./demo my.prof > profile.pdf

 

对于一个函数的CPU使用时间分析,分为两个部分:

1.整个函数消耗的CPU时间,包括函数内部其他函数调用所消耗的CPU时间

2.不包含内部其他函数调用所消耗的CPU时间(内联函数除外)

关于文本风格输出结果
序号 说明
1 分析样本数量(不包含其他函数调用)
2 分析样本百分比(不包含其他函数调用)
3 目前为止的分析样本百分比(不包含其他函数调用)
4 分析样本数量(包含其他函数调用)
5 分析样本百分比(包含其他函数调用)
6 函数名

 

关于图形风格输出结果

1.节点

每个节点代表一个函数,节点数据格式:

Class Name
Method Name
local (percentage)
of cumulative (percentage)

local时间是函数直接执行的指令所消耗的CPU时间(包括内联函数);性能分析通过抽样方法完成,默认是1秒100个样本,一个样本是10毫秒,即时间单位是10毫秒;

cumulative时间是local时间与其他函数调用的总和;

如果cumulative时间与local时间相同,则不打印cumulative时间项。

2.有向边

调用者指向被调用者,有向边上的时间表示被调用者所消耗的CPU时间

 

示例

代码如下,可以看出,CPU消耗集中在func1()和func2()两个函数,func2()消耗时间约为func1()的两倍。

复制代码
#include <google/profiler.h>
#include <iostream>
using namespace std;
void func1() {int i = 0;while (i < 100000) {++i;}  
}
void func2() {int i = 0;while (i < 200000) {++i;}  
}
void func3() {for (int i = 0; i < 1000; ++i) {func1();func2();}  
}
int main(){ProfilerStart("my.prof"); // 指定所生成的profile文件名
    func3();ProfilerStop(); // 结束profilingreturn 0;
}
复制代码

 

然后编译链接运行,使用pprof生成分析结果

g++ -o demo demo.cpp -lprofiler -lunwind
pprof --text ./demo my.prof > output.txt
pprof --pdf ./demo my.prof > output.pdf

查看分析结果,程序是122个时间样本,其中,func1()是40个时间样本,约为400毫秒;func2()是82个时间样本,约为820毫秒。

Total: 122 samples
       82  67.2%  67.2%       82  67.2% func2
       40  32.8% 100.0%       40  32.8% func1
        0   0.0% 100.0%      122 100.0% __libc_start_main
        0   0.0% 100.0%      122 100.0% _start
        0   0.0% 100.0%      122 100.0% func3
        0   0.0% 100.0%      122 100.0% main

 

 


这篇关于ldd gperftool 用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023812

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

Mysql中isnull,ifnull,nullif的用法及语义详解

《Mysql中isnull,ifnull,nullif的用法及语义详解》MySQL中ISNULL判断表达式是否为NULL,IFNULL替换NULL值为指定值,NULLIF在表达式相等时返回NULL,用... 目录mysql中isnull,ifnull,nullif的用法1. ISNULL(expr) → 判

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.