Skip to content

Commit

Permalink
Merge pull request #4898 from onflow/yahya/improve-libp2p-logging
Browse files Browse the repository at this point in the history
[Networking] Improves p2p node logging
  • Loading branch information
yhassanzadeh13 authored Nov 14, 2023
2 parents 5d07b31 + 4eeb13c commit fa7a065
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 8 deletions.
2 changes: 1 addition & 1 deletion network/p2p/connection/connector.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ var _ p2p.PeerUpdater = (*PeerUpdater)(nil)
// - error: an error if there is any error while creating the connector. The errors are irrecoverable and unexpected.
func NewPeerUpdater(cfg *PeerUpdaterConfig) (*PeerUpdater, error) {
libP2PConnector := &PeerUpdater{
log: cfg.Logger,
log: cfg.Logger.With().Str("component", "peer-updater").Logger(),
connector: cfg.Connector,
host: cfg.Host,
pruneConnections: cfg.PruneConnections,
Expand Down
14 changes: 8 additions & 6 deletions network/p2p/p2pbuilder/libp2pNodeBuilder.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import (
p2pconfig "github.com/onflow/flow-go/network/p2p/p2pbuilder/config"
gossipsubbuilder "github.com/onflow/flow-go/network/p2p/p2pbuilder/gossipsub"
"github.com/onflow/flow-go/network/p2p/p2pconf"
"github.com/onflow/flow-go/network/p2p/p2plogging"
"github.com/onflow/flow-go/network/p2p/p2pnode"
"github.com/onflow/flow-go/network/p2p/subscription"
"github.com/onflow/flow-go/network/p2p/tracer"
Expand Down Expand Up @@ -237,6 +238,7 @@ func (builder *LibP2PNodeBuilder) Build() (p2p.LibP2PNode, error) {
return nil, err
}
builder.gossipSubBuilder.SetHost(h)
lg := builder.logger.With().Str("local_peer_id", p2plogging.PeerId(h.ID())).Logger()

pCache, err := p2pnode.NewProtocolPeerCache(builder.logger, h)
if err != nil {
Expand All @@ -252,29 +254,29 @@ func (builder *LibP2PNodeBuilder) Build() (p2p.LibP2PNode, error) {
peerUpdater, err := connection.NewPeerUpdater(
&connection.PeerUpdaterConfig{
PruneConnections: builder.peerManagerConfig.ConnectionPruning,
Logger: builder.logger,
Logger: lg,
Host: connection.NewConnectorHost(h),
Connector: connector,
})
if err != nil {
return nil, fmt.Errorf("failed to create libp2p connector: %w", err)
}

peerManager = connection.NewPeerManager(builder.logger, builder.peerManagerConfig.UpdateInterval, peerUpdater)
peerManager = connection.NewPeerManager(lg, builder.peerManagerConfig.UpdateInterval, peerUpdater)

if builder.unicastConfig.RateLimiterDistributor != nil {
builder.unicastConfig.RateLimiterDistributor.AddConsumer(peerManager)
}
}

node := builder.createNode(builder.logger, h, pCache, peerManager, builder.disallowListCacheCfg)
node := builder.createNode(lg, h, pCache, peerManager, builder.disallowListCacheCfg)

if builder.connGater != nil {
builder.connGater.SetDisallowListOracle(node)
}

unicastManager, err := unicast.NewUnicastManager(&unicast.ManagerConfig{
Logger: builder.logger,
Logger: lg,
StreamFactory: stream.NewLibP2PStreamFactory(h),
SporkId: builder.sporkId,
ConnStatus: node,
Expand All @@ -288,7 +290,7 @@ func (builder *LibP2PNodeBuilder) Build() (p2p.LibP2PNode, error) {
MaxDialRetryAttemptTimes: builder.unicastConfig.MaxDialRetryAttemptTimes,
DialConfigCacheFactory: func(configFactory func() unicast.DialConfig) unicast.DialConfigCache {
return unicastcache.NewDialConfigCache(builder.unicastConfig.DialConfigCacheSize,
builder.logger,
lg,
metrics.DialConfigCacheMetricFactory(builder.metricsConfig.HeroCacheFactory, builder.networkingType),
configFactory)
},
Expand All @@ -310,7 +312,7 @@ func (builder *LibP2PNodeBuilder) Build() (p2p.LibP2PNode, error) {
ctx.Throw(fmt.Errorf("could not set routing system: %w", err))
}
builder.gossipSubBuilder.SetRoutingSystem(routingSystem)
builder.logger.Debug().Msg("routing system created")
lg.Debug().Msg("routing system created")
}
// gossipsub is created here, because it needs to be created during the node startup.
gossipSub, err := builder.gossipSubBuilder.Build(ctx)
Expand Down
3 changes: 2 additions & 1 deletion network/validator/target_validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,8 @@ func (tv *TargetValidator) Validate(msg network.IncomingMessageScope) bool {
}
}
tv.log.Debug().
Hex("target", logging.ID(tv.target)).
Hex("message_target_id", logging.ID(tv.target)).
Hex("local_node_id", logging.ID(tv.target)).
Hex("event_id", msg.EventID()).
Msg("message not intended for target")
return false
Expand Down

0 comments on commit fa7a065

Please sign in to comment.