Skip to content

Commit

Permalink
Add flag to enable logging block times
Browse files Browse the repository at this point in the history
  • Loading branch information
cmmarslender committed Dec 18, 2023
1 parent 0e6b775 commit 9d284e2
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 5 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@ main
bin/
GeoLite2-*.mmdb
.idea/*
*.log
3 changes: 3 additions & 0 deletions cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ func init() {
logLevel string
requestTimeout time.Duration
disableCentralHarvesterCollection bool
logBlockTimes bool
)

cobra.OnInitialize(initConfig)
Expand All @@ -46,13 +47,15 @@ func init() {
rootCmd.PersistentFlags().StringVar(&logLevel, "log-level", "info", "How verbose the logs should be. panic, fatal, error, warn, info, debug, trace")
rootCmd.PersistentFlags().DurationVar(&requestTimeout, "rpc-timeout", 10*time.Second, "How long RPC requests will wait before timing out")
rootCmd.PersistentFlags().BoolVar(&disableCentralHarvesterCollection, "disable-central-harvester-collection", false, "Disables collection of harvester information via the farmer. Useful for very large farms where this request is very expensive, or cases where chia-exporter is already installed on all harvesters")
rootCmd.PersistentFlags().BoolVar(&logBlockTimes, "log-block-times", false, "Enables logging of block (pre)validation times to log files.")

cobra.CheckErr(viper.BindPFlag("hostname", rootCmd.PersistentFlags().Lookup("hostname")))
cobra.CheckErr(viper.BindPFlag("metrics-port", rootCmd.PersistentFlags().Lookup("metrics-port")))
cobra.CheckErr(viper.BindPFlag("maxmind-db-path", rootCmd.PersistentFlags().Lookup("maxmind-db-path")))
cobra.CheckErr(viper.BindPFlag("log-level", rootCmd.PersistentFlags().Lookup("log-level")))
cobra.CheckErr(viper.BindPFlag("rpc-timeout", rootCmd.PersistentFlags().Lookup("rpc-timeout")))
cobra.CheckErr(viper.BindPFlag("disable-central-harvester-collection", rootCmd.PersistentFlags().Lookup("disable-central-harvester-collection")))
cobra.CheckErr(viper.BindPFlag("log-block-times", rootCmd.PersistentFlags().Lookup("log-block-times")))
}

// initConfig reads in config file and ENV variables if set.
Expand Down
13 changes: 8 additions & 5 deletions internal/metrics/fullnode.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (
"github.com/chia-network/go-chia-libs/pkg/types"
"github.com/prometheus/client_golang/prometheus"
log "github.com/sirupsen/logrus"
"github.com/spf13/viper"

wrappedPrometheus "github.com/chia-network/go-modules/pkg/prometheus"

Expand Down Expand Up @@ -316,11 +317,13 @@ func (s *FullNodeServiceMetrics) Block(resp *types.WebsocketResponse) {
s.preValidationTime.Set(block.PreValidationTime)
s.validationTime.Set(block.ValidationTime)

if err = utils.LogToFile("preValidationTime.log", fmt.Sprintf("%f", block.PreValidationTime)); err != nil {
log.Error(err.Error())
}
if err = utils.LogToFile("validationTime.log", fmt.Sprintf("%f", block.ValidationTime)); err != nil {
log.Error(err.Error())
if viper.GetBool("log-block-times") {
if err = utils.LogToFile("preValidationTime.log", fmt.Sprintf("%f", block.PreValidationTime)); err != nil {
log.Error(err.Error())
}
if err = utils.LogToFile("validationTime.log", fmt.Sprintf("%f", block.ValidationTime)); err != nil {
log.Error(err.Error())
}
}

if block.TransactionBlock {
Expand Down

0 comments on commit 9d284e2

Please sign in to comment.