refactor: add some metrics

This commit is contained in:
710leo 2020-03-19 12:45:33 +08:00
parent 1e05be4eec
commit 5df96d41a7
16 changed files with 44 additions and 20 deletions

View File

@ -74,7 +74,7 @@ func getCollects() (CollectResp, error) {
url := fmt.Sprintf("http://%s%s%s", addr, StraConfig.Api, identity.Identity) url := fmt.Sprintf("http://%s%s%s", addr, StraConfig.Api, identity.Identity)
err = httplib.Get(url).SetTimeout(time.Duration(StraConfig.Timeout) * time.Millisecond).ToJSON(&res) err = httplib.Get(url).SetTimeout(time.Duration(StraConfig.Timeout) * time.Millisecond).ToJSON(&res)
if err != nil { if err != nil {
err = fmt.Errorf("get collects from remote failed, error:%v", err) err = fmt.Errorf("get collects from remote:%s failed, error:%v", url, err)
} }
return res, err return res, err

View File

@ -48,7 +48,9 @@ func Push(items []*dataobj.MetricValue) {
logger.Error(err) logger.Error(err)
continue continue
} else { } else {
logger.Info("push succ, reply: ", reply) if reply.Msg != "ok" {
logger.Error("some item push err", reply)
}
return return
} }
} }

View File

@ -6,6 +6,7 @@ import (
"time" "time"
"github.com/didi/nightingale/src/toolkits/address" "github.com/didi/nightingale/src/toolkits/address"
"github.com/didi/nightingale/src/toolkits/stats"
"github.com/toolkits/pkg/concurrent/semaphore" "github.com/toolkits/pkg/concurrent/semaphore"
"github.com/toolkits/pkg/logger" "github.com/toolkits/pkg/logger"
@ -49,11 +50,12 @@ func reportEndpoint(endpoints []interface{}) {
err := httplib.Post(url).JSONBodyQuiet(m).SetTimeout(3*time.Second).Header("x-srv-token", "monapi-builtin-token").ToJSON(&body) err := httplib.Post(url).JSONBodyQuiet(m).SetTimeout(3*time.Second).Header("x-srv-token", "monapi-builtin-token").ToJSON(&body)
if err != nil { if err != nil {
logger.Warningf("curl %s fail: %v. retry", url, err) logger.Warningf("curl %s fail: %v. retry", url, err)
stats.Counter.Set("report.endpoint.err", 1)
continue continue
} }
if body.Err != "" { //数据库连接出错会出现此情况
if body.Err != "" {
logger.Warningf("curl %s fail: %s. retry", url, body.Err) logger.Warningf("curl %s fail: %s. retry", url, body.Err)
stats.Counter.Set("report.endpoint.err", 1)
continue continue
} }

View File

@ -19,6 +19,7 @@ import (
"github.com/didi/nightingale/src/toolkits/compress" "github.com/didi/nightingale/src/toolkits/compress"
"github.com/didi/nightingale/src/toolkits/identity" "github.com/didi/nightingale/src/toolkits/identity"
"github.com/didi/nightingale/src/toolkits/report" "github.com/didi/nightingale/src/toolkits/report"
"github.com/didi/nightingale/src/toolkits/stats"
) )
type CacheSection struct { type CacheSection struct {
@ -72,8 +73,8 @@ func StartPersist(interval int) {
err := Persist("normal") err := Persist("normal")
if err != nil { if err != nil {
logger.Error("Persist err:", err) logger.Error("Persist err:", err)
stats.Counter.Set("persist.err", 1)
} }
//logger.Infof("clean %+v, took %.2f ms\n", cleanRet, float64(time.Since(start).Nanoseconds())*1e-6)
} }
} }

View File

@ -42,6 +42,5 @@ func Push(event *dataobj.Event) error {
return nil return nil
} }
stats.Counter.Set("redis.failed", 1)
return fmt.Errorf("redis publish failed finally:%v", err) return fmt.Errorf("redis publish failed finally:%v", err)
} }

View File

@ -4,6 +4,7 @@ import (
"log" "log"
"time" "time"
"github.com/didi/nightingale/src/toolkits/stats"
"github.com/garyburd/redigo/redis" "github.com/garyburd/redigo/redis"
"github.com/toolkits/pkg/logger" "github.com/toolkits/pkg/logger"
) )
@ -44,6 +45,7 @@ func Init(cfg RedisSection) {
c, err := redis.Dial("tcp", addr, redis.DialConnectTimeout(connTimeout), redis.DialReadTimeout(readTimeout), redis.DialWriteTimeout(writeTimeout)) c, err := redis.Dial("tcp", addr, redis.DialConnectTimeout(connTimeout), redis.DialReadTimeout(readTimeout), redis.DialWriteTimeout(writeTimeout))
if err != nil { if err != nil {
logger.Errorf("conn redis err:%v", err) logger.Errorf("conn redis err:%v", err)
stats.Counter.Set("redis.conn.failed", 1)
return nil, err return nil, err
} }
@ -51,6 +53,8 @@ func Init(cfg RedisSection) {
if _, err := c.Do("AUTH", pass); err != nil { if _, err := c.Do("AUTH", pass); err != nil {
c.Close() c.Close()
logger.Errorf("ERR: redis auth fail:%v", err) logger.Errorf("ERR: redis auth fail:%v", err)
stats.Counter.Set("redis.conn.failed", 1)
return nil, err return nil, err
} }
} }

View File

@ -65,7 +65,7 @@ func Judge(stra *model.Stra, exps []model.Exp, historyData []*dataobj.RRDData, f
stats.Counter.Set("running", 1) stats.Counter.Set("running", 1)
if len(exps) < 1 { if len(exps) < 1 {
stats.Counter.Set("stra.err", 1) stats.Counter.Set("stra.illegal", 1)
logger.Warningf("stra:%v exp is null", stra) logger.Warningf("stra:%v exp is null", stra)
return return
} }
@ -421,6 +421,7 @@ func sendEvent(event *dataobj.Event) {
err := redi.Push(event) err := redi.Push(event)
if err != nil { if err != nil {
stats.Counter.Set("redis.push.failed", 1)
logger.Errorf("push event:%v err:%v", event, err) logger.Errorf("push event:%v err:%v", event, err)
} }
} }

View File

@ -56,11 +56,13 @@ func getStrategy(opts StrategySection) {
if err != nil { if err != nil {
logger.Warningf("get strategy from remote failed, error:%v", err) logger.Warningf("get strategy from remote failed, error:%v", err)
stats.Counter.Set("stra.get.err", 1)
continue continue
} }
if resp.Err != "" { if resp.Err != "" {
logger.Warningf("get strategy from remote failed, error:%v", resp.Err) logger.Warningf("get strategy from remote failed, error:%v", resp.Err)
stats.Counter.Set("stra.get.err", 1)
continue continue
} }

View File

@ -11,6 +11,7 @@ import (
"github.com/didi/nightingale/src/model" "github.com/didi/nightingale/src/model"
"github.com/didi/nightingale/src/modules/monapi/config" "github.com/didi/nightingale/src/modules/monapi/config"
"github.com/didi/nightingale/src/modules/monapi/scache" "github.com/didi/nightingale/src/modules/monapi/scache"
"github.com/didi/nightingale/src/toolkits/stats"
) )
func CheckJudgeLoop() { func CheckJudgeLoop() {
@ -19,6 +20,7 @@ func CheckJudgeLoop() {
time.Sleep(duration) time.Sleep(duration)
err := CheckJudge() err := CheckJudge()
if err != nil { if err != nil {
stats.Counter.Set("get.judge.err", 1)
logger.Error("check judge fail: ", err) logger.Error("check judge fail: ", err)
} }
} }

View File

@ -7,6 +7,7 @@ import (
"github.com/toolkits/pkg/logger" "github.com/toolkits/pkg/logger"
"github.com/didi/nightingale/src/modules/monapi/config" "github.com/didi/nightingale/src/modules/monapi/config"
"github.com/didi/nightingale/src/toolkits/stats"
) )
var RedisConnPool *redis.Pool var RedisConnPool *redis.Pool
@ -29,6 +30,8 @@ func InitRedis() {
Dial: func() (redis.Conn, error) { Dial: func() (redis.Conn, error) {
c, err := redis.Dial("tcp", addr, redis.DialConnectTimeout(connTimeout), redis.DialReadTimeout(readTimeout), redis.DialWriteTimeout(writeTimeout)) c, err := redis.Dial("tcp", addr, redis.DialConnectTimeout(connTimeout), redis.DialReadTimeout(readTimeout), redis.DialWriteTimeout(writeTimeout))
if err != nil { if err != nil {
logger.Errorf("conn redis err:%v", err)
stats.Counter.Set("redis.conn.failed", 1)
return nil, err return nil, err
} }
@ -36,6 +39,7 @@ func InitRedis() {
if _, err := c.Do("AUTH", pass); err != nil { if _, err := c.Do("AUTH", pass); err != nil {
c.Close() c.Close()
logger.Error("redis auth fail, pass: ", pass) logger.Error("redis auth fail, pass: ", pass)
stats.Counter.Set("redis.conn.failed", 1)
return nil, err return nil, err
} }
} }

View File

@ -12,6 +12,7 @@ import (
"github.com/didi/nightingale/src/dataobj" "github.com/didi/nightingale/src/dataobj"
"github.com/didi/nightingale/src/modules/transfer/calc" "github.com/didi/nightingale/src/modules/transfer/calc"
"github.com/didi/nightingale/src/toolkits/address" "github.com/didi/nightingale/src/toolkits/address"
"github.com/didi/nightingale/src/toolkits/stats"
"github.com/toolkits/pkg/logger" "github.com/toolkits/pkg/logger"
"github.com/toolkits/pkg/net/httplib" "github.com/toolkits/pkg/net/httplib"
@ -161,10 +162,12 @@ func fetchDataSync(start, end int64, consolFun, endpoint, counter string, step i
defer func() { defer func() {
<-worker <-worker
}() }()
stats.Counter.Set("query.tsdb", 1)
data, err := fetchData(start, end, consolFun, endpoint, counter, step) data, err := fetchData(start, end, consolFun, endpoint, counter, step)
if err != nil { if err != nil {
logger.Warning(err) logger.Warning(err)
stats.Counter.Set("query.data.err", 1)
} }
dataChan <- data dataChan <- data
return return

View File

@ -107,6 +107,7 @@ func Send2TsdbTask(Q *list.SafeListLimited, node string, addr string, concurrent
// 将数据 打入 某个Tsdb的发送缓存队列, 具体是哪一个Tsdb 由一致性哈希 决定 // 将数据 打入 某个Tsdb的发送缓存队列, 具体是哪一个Tsdb 由一致性哈希 决定
func Push2TsdbSendQueue(items []*dataobj.MetricValue) { func Push2TsdbSendQueue(items []*dataobj.MetricValue) {
errCnt := 0
for _, item := range items { for _, item := range items {
tsdbItem := convert2TsdbItem(item) tsdbItem := convert2TsdbItem(item)
stats.Counter.Set("tsdb.queue.push", 1) stats.Counter.Set("tsdb.queue.push", 1)
@ -118,19 +119,18 @@ func Push2TsdbSendQueue(items []*dataobj.MetricValue) {
} }
cnode := Config.ClusterList[node] cnode := Config.ClusterList[node]
errCnt := 0
for _, addr := range cnode.Addrs { for _, addr := range cnode.Addrs {
Q := TsdbQueues[node+addr] Q := TsdbQueues[node+addr]
if !Q.PushFront(tsdbItem) { if !Q.PushFront(tsdbItem) {
errCnt += 1 errCnt += 1
} }
} }
}
// statistics // statistics
if errCnt > 0 { if errCnt > 0 {
stats.Counter.Set("tsdb.queue.err", errCnt) stats.Counter.Set("tsdb.queue.err", errCnt)
logger.Error("Push2TsdbSendQueue err num: ", errCnt) logger.Error("Push2TsdbSendQueue err num: ", errCnt)
}
} }
} }
@ -172,7 +172,7 @@ func Send2JudgeTask(Q *list.SafeListLimited, addr string, concurrent int) {
if !sendOk { if !sendOk {
stats.Counter.Set("points.out.judge.err", 1) stats.Counter.Set("points.out.judge.err", 1)
logger.Errorf("send judge %s fail: %v", addr, err) logger.Errorf("send %v to judge %s fail: %v", judgeItems, addr, err)
} }
}(addr, judgeItems, count) }(addr, judgeItems, count)
@ -180,6 +180,7 @@ func Send2JudgeTask(Q *list.SafeListLimited, addr string, concurrent int) {
} }
func Push2JudgeSendQueue(items []*dataobj.MetricValue) { func Push2JudgeSendQueue(items []*dataobj.MetricValue) {
errCnt := 0
for _, item := range items { for _, item := range items {
key := str.PK(item.Metric, item.Endpoint) key := str.PK(item.Metric, item.Endpoint)
stras := cache.StraMap.GetByKey(key) stras := cache.StraMap.GetByKey(key)
@ -203,11 +204,13 @@ func Push2JudgeSendQueue(items []*dataobj.MetricValue) {
q, exists := JudgeQueues.Get(stra.JudgeInstance) q, exists := JudgeQueues.Get(stra.JudgeInstance)
if exists { if exists {
q.PushFront(judgeItem) if !q.PushFront(judgeItem) {
errCnt += 1
}
} }
} }
} }
stats.Counter.Set("judge.queue.err", errCnt)
} }
// 打到Tsdb的数据,要根据rrdtool的特定 来限制 step、counterType、timestamp // 打到Tsdb的数据,要根据rrdtool的特定 来限制 step、counterType、timestamp

View File

@ -27,9 +27,10 @@ func (t *Transfer) Push(args []*dataobj.MetricValue, reply *dataobj.TransferResp
err := v.CheckValidity() err := v.CheckValidity()
if err != nil { if err != nil {
stats.Counter.Set("points.in.err", 1) stats.Counter.Set("points.in.err", 1)
logger.Warningf("item is illegal item:%s err:%v", v, err) msg := fmt.Sprintf("item is illegal item:%s err:%v", v, err)
logger.Warningf(msg)
reply.Invalid += 1 reply.Invalid += 1
reply.Msg += fmt.Sprintf("%v\n", err) reply.Msg += msg
continue continue
} }

View File

@ -47,7 +47,7 @@ func GetIndexLoop() {
func GetIndex() { func GetIndex() {
instances, err := report.GetAlive("index", Config.HbsMod) instances, err := report.GetAlive("index", Config.HbsMod)
if err != nil { if err != nil {
stats.Counter.Set("index.get.err", 1) stats.Counter.Set("get.index.err", 1)
logger.Warningf("get index list err:%v", err) logger.Warningf("get index list err:%v", err)
return return
} }

View File

@ -58,7 +58,6 @@ func handleItems(items []*dataobj.TsdbItem) {
//todo hash冲突问题需要解决 //todo hash冲突问题需要解决
if err := cache.Caches.Push(item.Key, item.Timestamp, item.Value); err != nil { if err := cache.Caches.Push(item.Key, item.Timestamp, item.Value); err != nil {
stats.Counter.Set("points.in.err", 1) stats.Counter.Set("points.in.err", 1)
logger.Warningf("push obj error, obj: %v, error: %v\n", items[i], err) logger.Warningf("push obj error, obj: %v, error: %v\n", items[i], err)
fail++ fail++
} }

View File

@ -231,6 +231,7 @@ func FlushRRD(flushChunks map[interface{}][]*cache.Chunk) {
err := FlushFile(seriesID, items) err := FlushFile(seriesID, items)
if err != nil { if err != nil {
stats.Counter.Set("flush.rrd.err", 1)
logger.Errorf("flush %v data to rrd err:%v", seriesID, err) logger.Errorf("flush %v data to rrd err:%v", seriesID, err)
continue continue
} }