| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- package common
- import (
- "fmt"
- "github.com/shirou/gopsutil/cpu"
- "os"
- "runtime/pprof"
- "time"
- )
- // Monitor 定时监控cpu使用率,超过阈值输出pprof文件
- func Monitor() {
- for {
- percent, err := cpu.Percent(time.Second, false)
- if err != nil {
- panic(err)
- }
- if percent[0] > 80 {
- fmt.Println("cpu usage too high")
- // write pprof file
- if _, err := os.Stat("./pprof"); os.IsNotExist(err) {
- err := os.Mkdir("./pprof", os.ModePerm)
- if err != nil {
- SysLog("创建pprof文件夹失败 " + err.Error())
- continue
- }
- }
- f, err := os.Create("./pprof/" + fmt.Sprintf("cpu-%s.pprof", time.Now().Format("20060102150405")))
- if err != nil {
- SysLog("创建pprof文件失败 " + err.Error())
- continue
- }
- err = pprof.StartCPUProfile(f)
- if err != nil {
- SysLog("启动pprof失败 " + err.Error())
- continue
- }
- time.Sleep(10 * time.Second) // profile for 30 seconds
- pprof.StopCPUProfile()
- f.Close()
- }
- time.Sleep(30 * time.Second)
- }
- }
|