| | package common |
| |
|
| | import ( |
| | "fmt" |
| | "github.com/shirou/gopsutil/cpu" |
| | "os" |
| | "runtime/pprof" |
| | "time" |
| | ) |
| |
|
| | |
| | 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") |
| | |
| | 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) |
| | pprof.StopCPUProfile() |
| | f.Close() |
| | } |
| | time.Sleep(30 * time.Second) |
| | } |
| | } |
| |
|