Rumah > pembangunan bahagian belakang > Golang > 关于golang cpu性能分析

关于golang cpu性能分析

藏色散人
Lepaskan: 2020-12-25 16:04:18
ke hadapan
3100 orang telah melayarinya

下面由golang教程栏目给大家介绍golang cpu性能分析,希望对需要的朋友有所帮助!

关于golang cpu性能分析

一、分析程序的运行时间

(1)time指令(linux系统下)

time go run a.go
Salin selepas log masuk

real:从程序开始到结束,实际上度过的时间

user:程序在用户态度过的时间

sys:程序在内核度过的时间

一般情况下,real>=user+sys

(2) /usr/bin/time 指令(linux系统下)

/usr/bin/time -v go run a.go
Salin selepas log masuk

该指令下 可以看到 cpu占用率、 内存使用情况、 进程切换情况 、文件系统io、socket情况

二.golang下cpu性能分析

(1)在程序中引入 _ "net/http/pprof" ,并开启pprof监听  

 import _
Salin selepas log masuk
http.ListenAndServe("0.0.0.0:10000", nil)
Salin selepas log masuk
程序结束
Salin selepas log masuk

 通过浏览器查看 CPU的信息和状态 

http://127.0.0.1:10000/debug/pprof
Salin selepas log masuk

注意,等程序运⾏⼀定时间,再点击profile⽂件⽣成(⾄少是30s) 

(2)使用pprof

go tool pprof [binary] [profile] //binary二进制文件 profile 要分析的文件
Salin selepas log masuk
top //查看当前profile文件的cpu使用率
Salin selepas log masuk

flat 该函数⾃身代码的执⾏时⻓

flat% 该函数⾃身代码的执⾏时⻓占⽤CPU的耗时百分⽐

cum 代表的是该函数⾃身代码+所有调⽤的函数的执⾏时⻓

cum% 代表的是该函数⾃身代码+所有调⽤的函数的执⾏时⻓,占⽤CPU的总耗时百分⽐

sum% 每⼀⾏的flat%与上⾯所有⾏的flat%总和

(3)go tool pprof  profile文件 

       启动要调试的程序,在另一个终端执行 go tool pprof http://localhost:10000/debug/pprof/profile?seconds=60

(4)可视化结构图

先在终端运行 go tool pprof [binary] [profile] ,然后输入web,浏览器会弹出一个可视化的图片。
Salin selepas log masuk

更多相关技术文章,请访问go语言教程栏目!

Atas ialah kandungan terperinci 关于golang cpu性能分析. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:cnblogs.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan