性能分析
===
### 准备工作:
`sudo apt-get install graphviz`
go tool pprof 1.11以上版本默认有
### 通过文件方式输出Profile
- `go tool pprof [binary] [binary.prof]`
### 测试代码
~~~
func main() {
// cpu
file, err := os.Create("cpu.prof")
if err != nil {
panic(err.Error())
}
err = pprof.StartCPUProfile(file)
if err != nil {
panic(err.Error())
}
defer pprof.StopCPUProfile()
// cpu
var wg sync.WaitGroup
for i:=0;i<99;i++{
wg.Add(1)
go func() {
ps()
wg.Done()
}()
}
// 内存
mem, _ := os.Create("mem.prof")
pprof.WriteHeapProfile(mem)
// 多种tag
//gos, _ := os.Create("gorutine.prof")
//pprof.Lookup("")
wg.Wait()
}
~~~
### 查看报告
go tool pprof prof cpu.prof
生成测试图
输入
svg 就行
exit退出
### 以HTTP方式
![](https://box.kancloud.cn/a224fdc8070e5807b652baab5c76a04d_1160x319.png)
~~~
import (
_ "net/http/pprof"
)
~~~
[http://127.0.0.1:8081/debug/pprof/](http://127.0.0.1:8081/debug/pprof/)
- Hello World
- UDP
- UDP服务端
- UDP客户端
- UDP广播
- 错误处理
- 编写好的异常处理
- panic和recover
- 并发编程
- Hello Goruntine
- 共享内存并发机制
- RWMutex
- CSP并发机制
- 多路复用和超时控制
- 通道关闭与广播
- Context与任务的取消
- 只运行一次
- 按需任意任务完成
- 所有任务完成
- 补充:range channel注意实现
- 对象池
- sync.Pool临时对象池
- 单元测试
- 表格测试法
- Banchmark
- BDD
- 反射
- 利用反射编写灵活的代码
- Struct Tag
- 万能程序
- 常用架构模式
- Pipe-filter pattern
- Micro Kernel
- 性能分析
- 高性能代码
- sync.MAP分析
- Concurrent Map
- GC友好的代码
- Uber开发风格规范