Documentation ¶
Overview ¶
Package metrics provides service for collecting various metrics about peers. It is intended to be used with the kademlia where the metrics are collected.
Index ¶
- type Collector
- func (c *Collector) Exclude(addr swarm.Address, fop ...ExcludeOp) bool
- func (c *Collector) Finalize(t time.Time, remove bool) error
- func (c *Collector) Flush() error
- func (c *Collector) Inspect(addr swarm.Address) *Snapshot
- func (c *Collector) IsUnreachable(addr swarm.Address) bool
- func (c *Collector) Record(addr swarm.Address, rop ...RecordOp)
- func (c *Collector) Snapshot(t time.Time, addresses ...swarm.Address) map[string]*Snapshot
- type Counters
- type ExcludeOp
- type PeerConnectionDirection
- type RecordOp
- func IncSessionConnectionRetry() RecordOp
- func IsBootnode(b bool) RecordOp
- func PeerHealth(isHealty bool) RecordOp
- func PeerLatency(t time.Duration) RecordOp
- func PeerLogIn(t time.Time, dir PeerConnectionDirection) RecordOp
- func PeerLogOut(t time.Time) RecordOp
- func PeerReachability(s p2p.ReachabilityStatus) RecordOp
- type Snapshot
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Collector ¶
type Collector struct {
// contains filtered or unexported fields
}
Collector collects various metrics about peers specified be the swarm.Address.
func NewCollector ¶
NewCollector is a convenient constructor for creating new Collector.
func (*Collector) Exclude ¶ added in v2.2.0
Exclude returns false if the addr passes all exclusion operations.
func (*Collector) Flush ¶
Flush sync the dirty in memory counters for all peers by flushing their values to the underlying storage.
func (*Collector) Inspect ¶
Inspect allows inspecting current snapshot for the given peer address by executing the inspection function.
func (*Collector) IsUnreachable ¶
IsUnreachable returns true if the peer is unreachable.
func (*Collector) Snapshot ¶
Snapshot returns the current state of the metrics collector for peer(s). The given time t is used to calculate the duration of the current session, if any. If an address or a set of addresses is specified then only metrics related to them will be returned, otherwise metrics for all peers will be returned. If the peer is still logged in, the session-related counters will be evaluated against the last seen time, which equals to the login time. If the peer is logged out, then the session counters will reflect its last session.
type Counters ¶
type Counters struct { sync.Mutex IsBootnode bool ReachabilityStatus p2p.ReachabilityStatus Healthy bool // contains filtered or unexported fields }
Counters represents a collection of peer metrics mainly collected for statistics and debugging.
func (*Counters) MarshalJSON ¶
MarshalJSON marshals just the persistent counters.
func (*Counters) UnmarshalJSON ¶
UnmarshalJSON unmarshal just the persistent counters.
type ExcludeOp ¶ added in v2.2.0
ExcludeOp is a function type used to filter peers on certain fields.
func Bootnode ¶ added in v2.3.0
func Bootnode() ExcludeOp
IsBootnode is used to filter bootnode peers.
func Reachability ¶
Reachable is used to filter reachable or unreachable peers based on r.
type PeerConnectionDirection ¶
type PeerConnectionDirection string
PeerConnectionDirection represents peer connection direction.
const ( PeerConnectionDirectionInbound PeerConnectionDirection = "inbound" PeerConnectionDirectionOutbound PeerConnectionDirection = "outbound" )
type RecordOp ¶
type RecordOp func(*Counters)
RecordOp is a definition of a peer metrics Record operation whose execution modifies a specific metrics.
func IncSessionConnectionRetry ¶
func IncSessionConnectionRetry() RecordOp
IncSessionConnectionRetry increments the session connection retry counter by 1.
func IsBootnode ¶ added in v2.3.0
Bootnode will mark the peer metric as bootnode based on the bool arg.
func PeerHealth ¶
PeerHealth updates the last health status of a peers.
func PeerLatency ¶
PeerLatency records the average peer latency.
func PeerLogIn ¶
func PeerLogIn(t time.Time, dir PeerConnectionDirection) RecordOp
PeerLogIn will first update the current last seen to the give time t and as the second it'll set the direction of the session connection to the given value. The force flag will force the peer re-login if he's already logged in. The time is set as Unix timestamp ignoring the timezone. The operation will panic if the given time is before the Unix epoch.
func PeerLogOut ¶
PeerLogOut will first update the connection session and total duration with the difference of the given time t and the current last seen value. As the second it'll also update the last seen peer metrics to the given time t. The time is set as Unix timestamp ignoring the timezone. The operation will panic if the given time is before the Unix epoch.
func PeerReachability ¶
func PeerReachability(s p2p.ReachabilityStatus) RecordOp
PeerReachability updates the last reachability status.
type Snapshot ¶
type Snapshot struct { LastSeenTimestamp int64 SessionConnectionRetry uint64 ConnectionTotalDuration time.Duration SessionConnectionDuration time.Duration SessionConnectionDirection PeerConnectionDirection LatencyEWMA time.Duration Reachability p2p.ReachabilityStatus Healthy bool IsBootnode bool }
Snapshot represents a snapshot of peers' metrics counters.