mirror of
https://github.com/linux-do/new-api.git
synced 2025-09-18 00:16:37 +08:00
45 lines
1011 B
Go
45 lines
1011 B
Go
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)
|
||
}
|
||
}
|