Getting CPU usage
This commit is contained in:
parent
8206630289
commit
1265ca31c5
2 changed files with 49 additions and 7 deletions
14
index.html
14
index.html
|
@ -10,9 +10,15 @@
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<h1>Millics</h1>
|
<h1>Millics</h1>
|
||||||
<p>
|
<table>
|
||||||
This is kindof running maybe probs and has kindof no
|
<tr>
|
||||||
functionality yet.
|
<td>CPU</td>
|
||||||
</p>
|
<td>{{.CpuUsage}} %</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>sysLoad</td>
|
||||||
|
<td>{{.SysLoad}}</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
42
main.go
42
main.go
|
@ -19,10 +19,14 @@ type Config struct {
|
||||||
|
|
||||||
type page struct {
|
type page struct {
|
||||||
Title string
|
Title string
|
||||||
|
SysLoad string
|
||||||
|
CpuUsage string
|
||||||
}
|
}
|
||||||
|
|
||||||
var db *sql.DB
|
var db *sql.DB
|
||||||
|
|
||||||
|
var cpuUsage int8
|
||||||
|
var sysLoad float32
|
||||||
func main() {
|
func main() {
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
|
@ -58,7 +62,9 @@ func main() {
|
||||||
case <-done:
|
case <-done:
|
||||||
return
|
return
|
||||||
case t := <-tickerLAvgMin.C:
|
case t := <-tickerLAvgMin.C:
|
||||||
|
fmt.Printf("%v\n", t)
|
||||||
fetchLoadMinutely(t)
|
fetchLoadMinutely(t)
|
||||||
|
fetchCpuMinutely(t)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
@ -79,6 +85,8 @@ func httpRootHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
t, _ := template.ParseFiles("index.html")
|
t, _ := template.ParseFiles("index.html")
|
||||||
var p page
|
var p page
|
||||||
p.Title = "Millics"
|
p.Title = "Millics"
|
||||||
|
p.SysLoad = fmt.Sprint(sysLoad)
|
||||||
|
p.CpuUsage = fmt.Sprint(cpuUsage)
|
||||||
t.Execute(w, p)
|
t.Execute(w, p)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +95,7 @@ func initDB() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func fetchLoadMinutely(t time.Time) {
|
func fetchLoadMinutely(_t time.Time) {
|
||||||
file, err := os.Open("/proc/loadavg")
|
file, err := os.Open("/proc/loadavg")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("Error fetching load: %v\n", err)
|
fmt.Printf("Error fetching load: %v\n", err)
|
||||||
|
@ -101,7 +109,35 @@ func fetchLoadMinutely(t time.Time) {
|
||||||
fmt.Printf("Can't parse /proc/loadavg: %v\n", err)
|
fmt.Printf("Can't parse /proc/loadavg: %v\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf("sysLoad %v: %v/%v/%v\n", t, lavg1, lavg5, lavg15)
|
sysLoad = lavg1
|
||||||
|
fmt.Printf("sysLoad: %v/%v/%v\n", lavg1, lavg5, lavg15)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var lastCpuTotal, lastCpuTotalIdle uint64 = 0, 0
|
||||||
|
func fetchCpuMinutely(_t time.Time) {
|
||||||
|
file, err := os.Open("/proc/stat")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("Error fetching CPU usage: %v\n", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
|
var cpuUser, cpuNice, cpuSystem, cpuIdle, cpuIOWait, cpuIRQ, cpuSoftIRQ, cpuSteal uint64
|
||||||
|
var cpu string
|
||||||
|
ret, err := fmt.Fscanf(file, "%s %d %d %d %d %d %d %d %d", &cpu, &cpuUser, &cpuNice, &cpuSystem, &cpuIdle, &cpuIOWait, &cpuIRQ, &cpuSoftIRQ, &cpuSteal)
|
||||||
|
if err != nil || cpu != "cpu" || ret < 9 {
|
||||||
|
fmt.Printf("Can't parse /proc/stat: %v\n", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
cpuTotal := cpuUser + cpuNice + cpuSystem + cpuIdle + cpuIOWait + cpuIRQ + cpuSoftIRQ + cpuSteal
|
||||||
|
cpuTotalIdle := cpuIdle + cpuIOWait
|
||||||
|
if lastCpuTotal != 0 && lastCpuTotalIdle != 0 {
|
||||||
|
cpuUsage = int8(100-float32((cpuTotalIdle-lastCpuTotalIdle))/float32((cpuTotal-lastCpuTotal))*100)
|
||||||
|
fmt.Printf("CPU: %v %%\n", cpuUsage)
|
||||||
|
}
|
||||||
|
lastCpuTotal = cpuTotal
|
||||||
|
lastCpuTotalIdle = cpuTotalIdle
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue