From 20a5b20b5911305f57ef2700a58db3688e00fbb9 Mon Sep 17 00:00:00 2001 From: Ettore Di Giacinto Date: Thu, 7 Nov 2024 18:09:33 +0100 Subject: [PATCH] chore(p2p): enhance logging (#4090) Signed-off-by: Ettore Di Giacinto --- core/p2p/p2p.go | 16 ++++++++-------- core/p2p/p2p_common.go | 19 +++++++++++++++++++ 2 files changed, 27 insertions(+), 8 deletions(-) create mode 100644 core/p2p/p2p_common.go diff --git a/core/p2p/p2p.go b/core/p2p/p2p.go index 15e1dc37c81f..8601109a25c3 100644 --- a/core/p2p/p2p.go +++ b/core/p2p/p2p.go @@ -231,10 +231,14 @@ func discoveryTunnels(ctx context.Context, n *node.Node, token, servicesID strin data := ledger.LastBlock().Storage[servicesID] - zlog.Debug().Any("data", ledger.LastBlock().Storage).Msg("Ledger data") + if logLevel == logLevelDebug { + // We want to surface this debugging data only if p2p logging is set to debug + // (and not generally the whole application, as this can be really noisy) + zlog.Debug().Any("data", ledger.LastBlock().Storage).Msg("Ledger data") + } for k, v := range data { - zlog.Debug().Msgf("New worker found in the ledger data '%s'", k) + // New worker found in the ledger data as k (worker id) nd := &NodeData{} if err := v.Unmarshal(nd); err != nil { zlog.Error().Msg("cannot unmarshal node data") @@ -269,7 +273,7 @@ func ensureService(ctx context.Context, n *node.Node, nd *NodeData, sserv string if ndService, found := service[nd.Name]; !found { if !nd.IsOnline() { // if node is offline and not present, do nothing - zlog.Debug().Msgf("Node %s is offline", nd.ID) + // Node nd.ID is offline return } @@ -381,10 +385,6 @@ func newNodeOpts(token string) ([]node.Option, error) { noDHT := os.Getenv("LOCALAI_P2P_DISABLE_DHT") == "true" noLimits := os.Getenv("LOCALAI_P2P_ENABLE_LIMITS") == "true" - loglevel := os.Getenv("LOCALAI_P2P_LOGLEVEL") - if loglevel == "" { - loglevel = "info" - } libp2ploglevel := os.Getenv("LOCALAI_LIBP2P_LOGLEVEL") if libp2ploglevel == "" { libp2ploglevel = "fatal" @@ -396,7 +396,7 @@ func newNodeOpts(token string) ([]node.Option, error) { }, NetworkToken: token, LowProfile: false, - LogLevel: loglevel, + LogLevel: logLevel, Libp2pLogLevel: libp2ploglevel, Ledger: config.Ledger{ SyncInterval: defaultInterval, diff --git a/core/p2p/p2p_common.go b/core/p2p/p2p_common.go new file mode 100644 index 000000000000..2af5c77b74a2 --- /dev/null +++ b/core/p2p/p2p_common.go @@ -0,0 +1,19 @@ +package p2p + +import ( + "os" + "strings" +) + +var logLevel = strings.ToLower(os.Getenv("LOCALAI_P2P_LOGLEVEL")) + +const ( + logLevelDebug = "debug" + logLevelInfo = "info" +) + +func init() { + if logLevel == "" { + logLevel = logLevelInfo + } +}