erigon-pulse/cmd/observer/main.go
battlmonstr 92db317e06
Observer - P2P network crawler (#3928)
Observer crawls the Ethereum network and collects information about the nodes.
2022-04-22 12:02:12 +01:00

109 lines
2.8 KiB
Go

package main
import (
"context"
"errors"
"fmt"
"github.com/ledgerwatch/erigon-lib/common"
"github.com/ledgerwatch/erigon/cmd/observer/database"
"github.com/ledgerwatch/erigon/cmd/observer/observer"
"github.com/ledgerwatch/erigon/cmd/observer/reports"
"github.com/ledgerwatch/erigon/cmd/utils"
"github.com/ledgerwatch/erigon/params"
"github.com/ledgerwatch/log/v3"
"path/filepath"
)
func mainWithFlags(ctx context.Context, flags observer.CommandFlags) error {
server, err := observer.NewServer(flags)
if err != nil {
return err
}
db, err := database.NewDBSQLite(filepath.Join(flags.DataDir, "observer.sqlite"))
if err != nil {
return err
}
defer func() { _ = db.Close() }()
discV4, err := server.Listen(ctx)
if err != nil {
return err
}
networkID := uint(params.NetworkIDByChainName(flags.Chain))
go observer.StatusLoggerLoop(ctx, db, networkID, flags.StatusLogPeriod, log.Root())
crawlerConfig := observer.CrawlerConfig{
Chain: flags.Chain,
Bootnodes: server.Bootnodes(),
PrivateKey: server.PrivateKey(),
ConcurrencyLimit: flags.CrawlerConcurrency,
RefreshTimeout: flags.RefreshTimeout,
MaxPingTries: flags.MaxPingTries,
StatusLogPeriod: flags.StatusLogPeriod,
HandshakeRefreshTimeout: flags.HandshakeRefreshTimeout,
HandshakeRetryDelay: flags.HandshakeRetryDelay,
HandshakeMaxTries: flags.HandshakeMaxTries,
KeygenTimeout: flags.KeygenTimeout,
KeygenConcurrency: flags.KeygenConcurrency,
}
crawler, err := observer.NewCrawler(discV4, db, crawlerConfig, log.Root())
if err != nil {
return err
}
return crawler.Run(ctx)
}
func reportWithFlags(ctx context.Context, flags reports.CommandFlags) error {
db, err := database.NewDBSQLite(filepath.Join(flags.DataDir, "observer.sqlite"))
if err != nil {
return err
}
defer func() { _ = db.Close() }()
networkID := uint(params.NetworkIDByChainName(flags.Chain))
if flags.Estimate {
report, err := reports.CreateClientsEstimateReport(ctx, db, flags.ClientsLimit, flags.MaxPingTries, networkID)
if err != nil {
return err
}
fmt.Println(report)
return nil
}
statusReport, err := reports.CreateStatusReport(ctx, db, flags.MaxPingTries, networkID)
if err != nil {
return err
}
clientsReport, err := reports.CreateClientsReport(ctx, db, flags.ClientsLimit, flags.MaxPingTries, networkID)
if err != nil {
return err
}
fmt.Println(statusReport)
fmt.Println(clientsReport)
return nil
}
func main() {
ctx, cancel := common.RootContext()
defer cancel()
command := observer.NewCommand()
reportCommand := reports.NewCommand()
reportCommand.OnRun(reportWithFlags)
command.AddSubCommand(reportCommand.RawCommand())
err := command.ExecuteContext(ctx, mainWithFlags)
if (err != nil) && !errors.Is(err, context.Canceled) {
utils.Fatalf("%v", err)
}
}