| package common |
|
|
| import ( |
| "fmt" |
| "os" |
| "runtime/pprof" |
| "time" |
|
|
| "github.com/shirou/gopsutil/cpu" |
| ) |
|
|
| |
| 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) |
| } |
| } |
|
|