快速部署你自己的Perfetto服务器

本文作者:sonicman,首发于:AndroidPerformance联系方式:voidice#gmail.com转载请先向作者申请

前一篇文章:perfetto使用简介

前言

Perfetto 是 google 开源的新一代性能检测和追踪分析套件,网上已经有很多介绍文章了,官网文档也有非常详尽的描述,这里就不再翻译网站上的文字了。写这篇文档是为了回应网上的一个高价的收费教程,回馈一下国内的社区。没人按字数付版费,只能本着能省就省的原则,少打几个字了

很多朋友已经在日常的工作和学习中已经开始使用 Perfetto,它在查看大文件时速度较快,UI 也比较摩登一些,但是往往会遇到下面的两个主要问题:

网速太慢,上传至官方网站需要耗时很久公司网络有安全管控,容易发生信息泄露,引起不必要的麻烦

能不能自己也部署一套类似的系统呢?这样自己就可以随心所欲的定制了,答案肯定是可以, 而且很简单

google_perfetto_previe

1 Perfetto 简介

官方网站:

详细文档:

不能免俗,贴上一个原理图,让整个文档更美观:

perfetto_tech

2 准备工作

Ubuntu (18.x、20.x 均可,本人亲测都可以顺利运行), 其它 linux 发行版本也是可以的,但没有一一尝试

git

可以顺利访问 google/chrome/github 等技术网站的 proxy

3 下载 Perfetto 源代码

使用 git 将源代码 clone 至本地:

sonicman@Ubuntwo:~/p$ git clone [email protected]:google/perfetto.git正克隆到 perfetto...remote: Enumerating objects: 381, done.remote: Counting objects: 100% (381/381), done.remote: Compressing objects: 100% (245/245), done.remote: Total 77957 (delta 218), reused 235 (delta 136), pack-reused 77576接收对象中: 100% (77957/77957), 36.38 MiB | 55.00 KiB/s, 完成.处理 delta 中: 100% (40784/40784), 完成.

4 下载并安装网站依赖模块及工具

主要是 NodeJs 及 node_modules

// 切换到上面clone的目录sonic@sonicman:~/ServerData/perfetto$// 执行安装命令$tools/install-build-deps --ui

通常,你会在这里遇到各种下载错误,导致无法安装成功,这个时候就需要设置代理了

为 git command 设置代理

# git config --global http.proxy x.x.x.x:port // 记得改成你自己的代理服务器ip和端口# git config --global https.proxy x.x.x.x:port

为 curl 设置代理:

export http_proxy=:portexport https_proxy=:port

不要气馁,重新执行一下前面的安装命令,经过漫长的等待和多次重试,你一定会成功的

5. 编译 UI 套件

设置编译参数,其实只有一个 is_debug=true|false,作为一个普通的用户,我们就可以忽略这个开发调试开关

./tools/gn args out/default

生成 Perfetto 网站相关的内容

./tools/ninja -C out/default ui

没有报错的,到这里就顺利完成了,更多详细的编译指导,请移步

build-instructions[1]

6 启动服务器

使用以下命令启动服务

ui/run-dev-server out/default

使用浏览器打开::10000

激动人心的时刻到来了,恭喜你,部署成功,赶紧喝杯咖啡庆祝一下吧

preview

7 修改服务器默认的端口(如有需求)

vim perfetto/tools/dev_server// 找到port number,默认是3000, 修改成你想要的空白端口def main(argv):  parser = argparse.ArgumentParser(description=HTTP server for UI development)  parser.add_argument(      -p,      --port,      help=port number (default: 3000),      type=int,      default=3000)

修改服务器 IP 也类似,请自行查找

8. 常见的错误及处理

8.1 libtinfo.so.5 cannot open

/perfetto/buildtools/emsdk/llvm/clang++: error while loading shared libraries: libtinfo.so.5: cannot open shared object file: No such file or directoryERROR:root:compiler frontend failed to generate LLVM bitcode, haltingninja: build stopped: subcommand failed.// 解决方案:install libncurses5$sudo apt install libncurses5

好了,本次就先写到这里了,希望大家多多交流,做出更顶尖的性能分析工具套件

参考资料

[1]

build-instructions: /contributing/build-instructions