1
0
Fork 0
cpu_ctrl/consumer/influx_stat.go

108 lines
2.6 KiB
Go
Raw Normal View History

package consumer
import (
"amuz.es/src/infra/cpu_ctrl/util"
2017-09-11 07:41:59 +09:00
//"time"
"amuz.es/src/infra/cpu_ctrl/processor"
"amuz.es/src/infra/cpu_ctrl/logger"
2017-09-11 07:41:59 +09:00
//"github.com/influxdata/influxdb/client/v2"
)
var (
influxLogger = logger.NewLogger("influx")
)
type influxMetric struct {
host string
2017-09-11 07:41:59 +09:00
processorCount int
handler util.Handler
fanSpeedConsumer chan processor.FanspeedInfo
tempetureConsumer chan processor.TempetureInfo
}
type InfluxMetric interface {
FanSpeedConsumer() chan<- processor.FanspeedInfo
TempetureConsumer() chan<- processor.TempetureInfo
2017-09-11 07:41:59 +09:00
StartLogging()
}
2017-09-11 07:41:59 +09:00
func NewInfluxMetric(host string, processorCount int, handler util.Handler) InfluxMetric {
return &influxMetric{
host: host,
2017-09-11 07:41:59 +09:00
processorCount: processorCount,
handler: handler,
fanSpeedConsumer: make(chan processor.FanspeedInfo, 1),
tempetureConsumer: make(chan processor.TempetureInfo, 1),
}
}
func (m *influxMetric) FanSpeedConsumer() chan<- processor.FanspeedInfo { return m.fanSpeedConsumer }
func (m *influxMetric) TempetureConsumer() chan<- processor.TempetureInfo { return m.tempetureConsumer }
2017-09-11 07:41:59 +09:00
func (m *influxMetric) StartLogging() {
defer m.handler.DecreaseWait()
defer func() {
if err := recover(); err != nil {
m.handler.NotifyError(err.(error))
}
}()
2017-09-11 07:41:59 +09:00
//var influxDbConn client.Client
//for {
// conn, err := client.NewUDPClient(client.UDPConfig{Addr: m.host,})
// if err != nil {
// influxLogger.Error(err)
// } else {
// influxDbConn = conn
// break
// }
// cont := time.After(3 * time.Second)
// select {
// case <-cont:
// continue
// case <-m.handler.Done():
// return
// }
//}
//
//// Create a new point batch
//batchPoint, err := client.NewBatchPoints(client.BatchPointsConfig{
// Database: "core",
// Precision: "s",
//})
//if err != nil {
// panic(err)
//}
defer close(m.fanSpeedConsumer)
defer close(m.tempetureConsumer)
for {
select {
2017-09-11 07:41:59 +09:00
case changedSpeed := <-m.fanSpeedConsumer:
influxLogger.Debugf("id %d speed %d",changedSpeed.Id,changedSpeed.FanSpeed)
case changedTempeture := <-m.tempetureConsumer:
influxLogger.Debugf("id %d temp %f",changedTempeture.Id,changedTempeture.Tempeture)
case <-m.handler.Done():
return
}
}
2017-09-11 07:41:59 +09:00
//// Create a point and add to batch
//tags := map[string]string{"cpu": "cpu-total"}
//fields := map[string]interface{}{
// "idle": 10.1,
// "system": 53.3,
// "user": 46.6,
//}
//
2017-09-11 07:41:59 +09:00
//pt, err := client.NewPoint("cpu_usage", tags, fields, time.Now())
//if err != nil {
// log.Fatal(err)
//}
//batchPoint.AddPoint(pt)
//
//// Write the batch
//if err := influxDbConn.Write(batchPoint); err != nil {
// log.Fatal(err)
//}
}