Skip to content

Commit

Permalink
metrics: add expected height metric
Browse files Browse the repository at this point in the history
  • Loading branch information
travisperson committed Sep 6, 2020
1 parent c573310 commit 9d1ad34
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 0 deletions.
25 changes: 25 additions & 0 deletions chain/sync.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import (
logging "github.com/ipfs/go-log/v2"
"github.com/libp2p/go-libp2p-core/connmgr"
"github.com/libp2p/go-libp2p-core/peer"
"github.com/raulk/clock"
cbg "github.com/whyrusleeping/cbor-gen"
"github.com/whyrusleeping/pubsub"
"go.opencensus.io/stats"
Expand Down Expand Up @@ -125,6 +126,10 @@ type Syncer struct {
verifier ffiwrapper.Verifier

windowSize int

ticker *clock.Ticker
tickerCtx context.Context
tickerCtxCancel context.CancelFunc
}

// NewSyncer creates a new Syncer object.
Expand Down Expand Up @@ -166,11 +171,31 @@ func NewSyncer(sm *stmgr.StateManager, bsync *blocksync.BlockSync, connmgr connm
}

func (syncer *Syncer) Start() {
syncer.ticker = build.Clock.Ticker(time.Duration(build.BlockDelaySecs) * time.Second)
syncer.tickerCtx, syncer.tickerCtxCancel = context.WithCancel(context.Background())
syncer.syncmgr.Start()

genesisTime := time.Unix(int64(syncer.Genesis.MinTimestamp()), 0)

go func() {
for {
select {
case <-syncer.ticker.C:
sinceGenesis := build.Clock.Now().Sub(genesisTime)
expectedHeight := int64(sinceGenesis.Seconds()) / int64(build.BlockDelaySecs)

stats.Record(syncer.tickerCtx, metrics.ChainNodeHeightExpected.M(int64(expectedHeight)))
case <-syncer.tickerCtx.Done():
return
}
}
}()
}

func (syncer *Syncer) Stop() {
syncer.syncmgr.Stop()
syncer.ticker.Stop()
syncer.tickerCtxCancel()
}

// InformNewHead informs the syncer about a new potential tipset
Expand Down
6 changes: 6 additions & 0 deletions metrics/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ var (
var (
LotusInfo = stats.Int64("info", "Arbitrary counter to tag lotus info to", stats.UnitDimensionless)
ChainNodeHeight = stats.Int64("chain/node_height", "Current Height of the node", stats.UnitDimensionless)
ChainNodeHeightExpected = stats.Int64("chain/node_height_expected", "Expected Height of the node", stats.UnitDimensionless)
ChainNodeWorkerHeight = stats.Int64("chain/node_worker_height", "Current Height of workers on the node", stats.UnitDimensionless)
MessagePublished = stats.Int64("message/published", "Counter for total locally published messages", stats.UnitDimensionless)
MessageReceived = stats.Int64("message/received", "Counter for total received messages", stats.UnitDimensionless)
Expand Down Expand Up @@ -62,6 +63,10 @@ var (
Measure: ChainNodeHeight,
Aggregation: view.LastValue(),
}
ChainNodeHeightExpectedView = &view.View{
Measure: ChainNodeHeightExpected,
Aggregation: view.LastValue(),
}
ChainNodeWorkerHeightView = &view.View{
Measure: ChainNodeWorkerHeight,
Aggregation: view.LastValue(),
Expand Down Expand Up @@ -138,6 +143,7 @@ var (
var DefaultViews = append([]*view.View{
InfoView,
ChainNodeHeightView,
ChainNodeHeightExpectedView,
ChainNodeWorkerHeightView,
BlockReceivedView,
BlockValidationFailureView,
Expand Down

0 comments on commit 9d1ad34

Please sign in to comment.