最近在摆弄算法的的优化,需要剖分一下算法的瓶颈,就找了一些代码剖分工具,其中

gprofileer-tools是很不错的工具,gperftools时google开源的一款C++性能分析分析工具,github项目地址如下:

   https://github.com/gperftools/gperftools

  一 下载和安装:

  1.git clone:

2 . 安装:

   根目录下执行:sh autogen.sh

 然后执行:./configure

最后:make all && sudo make install

安装成功。

   如果没有安装libunwind会出现如,configure执行后报警告:   

configure: WARNING: No frame pointers and no libunwind. Using experimental backtrace capturing via libgcc. Expect crashy cpu profiler.

   解决方法:

使用命令apt-get install libunwind8-dev安装libunwind即可。

  3 最后使用ldconfig更新一下库文件即可。

  二 使用和实例:

  1 使用gprofiler-tools需要在的代码中添加如下几段代码:

   A头文件:

    #include <gperftools/profiler.h>

   B 起止函数:

    修改程序的源代码使得要profiler的代码段包含在ProfilerStart("name");ProfilerStop();

   C链接文件添加需要链接的宏:

    lprofiler //cpu性能

    -ltcmalloc  //heap资源

  2 实例:

#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <gperftools/profiler.h>
#include <unistd.h> void consumeSomeCPUTime1(int input){
int i = ;
input++;
while(i++ < ){
i--; i++; i--; i++;
}
}; void consumeSomeCPUTime2(int input){
input++;
consumeSomeCPUTime1(input);
int i = ;
while(i++ < ){
i--; i++; i--; i++;
}
}; int stupidComputing(int a, int b){
int i = ;
while( i++ < ){
consumeSomeCPUTime1(i);
}
int j = ;
while(j++ < ){
consumeSomeCPUTime2(j);
}
return a+b;
}; int smartComputing(int a, int b){
return a+b;
}; int main()
{
int i = ;
printf("reached the start point of performance bottle neck\n");
sleep();
ProfilerStart("CPUProfile");
while( i++ < ){
printf("Stupid computing return : %d\n",stupidComputing(i, i+));
printf("Smart computing return %d\n",smartComputing(i+, i+));
}
printf("should teminate profiling now.\n");
ProfilerStop();
sleep(); return ;
}

  编译运行:

gcc -g test.c -o prog -lprofiler

  

export CPUPROFILE=info.prof

  执行:

pprof -text prog info.prof

  结果:

Using local file prog.
Using local file info.prof.
Total: samples
75.4% 75.4% 75.4% consumeSomeCPUTime1
24.6% 100.0% 50.0% consumeSomeCPUTime2
0.0% 100.0% 100.0% __libc_start_main
0.0% 100.0% 100.0% _start
0.0% 100.0% 100.0% main
0.0% 100.0% 100.0% stupidComputing

 

报错一:

Google perftool cannot read file “libprofiler.so.0”

解决方法:

sudo /sbin/ldconfig

错误二:

Using local file prog.
Use of uninitialized value $host in substitution (s///) at /usr/local/bin/pprof line 3366.
Use of uninitialized value $hostport in concatenation (.) or string at /usr/local/bin/pprof line 3368.
Use of uninitialized value $prefix in concatenation (.) or string at /usr/local/bin/pprof line 3368.
Use of uninitialized value $host in substitution (s///) at /usr/local/bin/pprof line 3366.

解决方法:

env CPUPROFILE=/tmp/mybin.prof /home/gprofiler-tools/prog

参考资料:

1 https://www.kancloud.cn/subin/blog/619133

2 https://github.com/gperftools/gperftools

3 https://stackoverflow.com/questions/1581494/google-perftool-cannot-read-file-libprofiler-so-0

4    https://www.ibm.com/developerworks/cn/linux/l-cn-googleperf/index.html

5   https://stackoverflow.com/questions/24086867/cant-analyse-the-output-the-profile-file-of-gperftools-profiler

linux下应用程序性能剖分神器gprofiler-tools-安装和使用的更多相关文章

  1. VMware,win7与linux centos6.4文件互传,linux下挂载windows共享文件夹,vmware tools安装方法

    本方法是以win7,VMware9.0.1 ,centos6.4为基础实验的. 对于linux的初级使用阶段,都会Windows中使用linux虚拟机VMWare或者其它的.在Windows与linu ...

  2. linux下关于程序性能和系统性能的工具、方法

    观察性能/状态的方法:top free netstat /pro/目录下的信息 其中/pro/meminfo下的信息相当丰富 ------------------------------------- ...

  3. linux下c程序调用reboot函数实现直接重启【转】

    转自:http://www.blog.chinaunix.net/uid-20564848-id-73878.html linux下c程序调用reboot函数实现直接重启 当然你也可以直接调用syst ...

  4. Linux下C程序的编辑,编译和运行以及调试

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html 内部邀请码:C8E245J (不写邀请码,没有现金送) 国 ...

  5. 位图文件(BMP)格式以及Linux下C程序实现(转)

    源:位图文件(BMP)格式以及Linux下C程序实现 说到图片,位图(Bitmap)当然是最简单的,它是Windows显示图片的基本格式,其文件扩展名为*.BMP.由于没有经过任何的压缩,故BMP图 ...

  6. Linux下C程序内存泄露检测

    在linux下些C语言程序,最大的问题就是没有一个好的编程IDE,当然想kdevelop等工具都相当的强大,但我还是习惯使用kdevelop工具,由于没有一个习惯的编程IDE,内存检测也就成了在lin ...

  7. Linux下C程序的内存映像

    2.Linux下C程序的内存映像 2.1. 代码段.只读数据段(1)对应着程序中的代码(函数),代码段在Linux中又叫文本段(.text)(2)只读数据段就是在程序运行期间只能读不能写的数据,con ...

  8. Red Gate系列之五 .NET Reflector 7.6.1.824 Edition .NET程序反编译神器(附插件安装教程2012-10-13更新) 完全破解+使用教程

    原文:Red Gate系列之五 .NET Reflector 7.6.1.824 Edition .NET程序反编译神器(附插件安装教程2012-10-13更新) 完全破解+使用教程 Red Gate ...

  9. Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用

    Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用 hydra可以破解: http://www.thc.org/thc-hydra,可支持AFP, Cisco AAA, Cisco a ...

随机推荐

  1. ceph常用运维技巧总结1

    格式 json 数据增强可读性 --format json-pretty -f json-pretty ceph quorum_status -f json-pretty ceph mon_statu ...

  2. 学JS的心路历程 - JS应用

    各家电商网站都推出了各种活动和现今优惠券,当时在逛PTT时看到了有篇文章,提供代码教大家用JS的方式抢票,看了一下后发现好像很多人好奇这是怎么做的,于是就想说想一篇文章来讲解一下. 我们先来看一下折价 ...

  3. Django_Form验证(三)字段,字段的参数,widgets种类

    Form工具是一个很强大的工具,所以他的功能不仅仅是上面2个例子,这里详细记录一下Form的其他功能 字段的一般参数,以CharFields为列子: user=fields.CharField( re ...

  4. shell一出手

    1.查看有多少个IP访问: awk '{print $1}' log_file|sort|uniq|wc -l 2.查看某一个页面被访问的次数: grep "/index.php" ...

  5. Java17-java语法基础——泛型

    Java18-java语法基础——泛型 一.泛型概念和作用 1.泛型概念: 泛型是JavaSE1.5的新特性,泛型的本质是参数化类型,也就是说,所操作的数据类型被指定为一个参数.这种参数类型可以用在类 ...

  6. RHCS(概念篇)

    一. 什么是RHCS RHCS是Red Hat Cluster Suite的缩写,也就是红帽子集群套件,RHCS是一个能够提供高可用性.高可靠性.负载均衡.存储共享且经济廉价的集群工具集合,它将集群系 ...

  7. 三、putty工具常见设置

    转载自:https://www.cnblogs.com/hdk1993/p/4769072.html Putty是一个免费小巧的Win32平台下的telnet,rlogin和ssh客户端. 它的主程序 ...

  8. docker 支持ipv6 (核心要点是ndp需要把docker内的ip全部加入到ndplist中来)

    IPv6 with Docker Estimated reading time: 10 minutes The information in this section explains IPv6 wi ...

  9. Linux anaconda 内网 安装 卸载

    安装并不难, 官网介绍的很清楚, 但每次到官网找安装方法不方便,我总结了本文(很全) 官网下载Linux版anaconda, 地址https://www.anaconda.com/download/# ...

  10. Linux 6上使用UDEV绑定共享存储

    1.硬盘的查看方式 [root@cl6-11gr2-rac1 ~]# ls -ltr /dev/sd* brw-rw----. 1 root disk 8, 48 8月 16 13:34 /dev/s ...