From fc2c3995a6ecb08166df5c59ff8a3b8fd800f2bd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Thu, 18 Jul 2024 12:29:48 +0200 Subject: [PATCH] Print cfg and intervals --- hostmetadata/host/host.go | 3 ++- otel/builder-config.yaml | 2 +- otel/receiver/config.go | 1 - otel/receiver/trace-receiver.go | 29 ++++++++++++++++++++++++++--- tracehandler/tracehandler.go | 2 ++ tracer/events.go | 3 +++ tracer/tracer.go | 1 + 7 files changed, 35 insertions(+), 6 deletions(-) diff --git a/hostmetadata/host/host.go b/hostmetadata/host/host.go index 4344d388..4f75d409 100644 --- a/hostmetadata/host/host.go +++ b/hostmetadata/host/host.go @@ -68,7 +68,8 @@ var ( // default. func AddMetadata(result map[string]string) error { caEndpoint := agent.GetCollectionAgentAddr() - // Extract the host part of the endpoint + log.Debugf("coll agent endpoint: %s", caEndpoint) + // Remove the port from the endpoint in case it is present host, _, err := net.SplitHostPort(caEndpoint) if err != nil { diff --git a/otel/builder-config.yaml b/otel/builder-config.yaml index e3e59767..d06c36af 100644 --- a/otel/builder-config.yaml +++ b/otel/builder-config.yaml @@ -18,6 +18,6 @@ receivers: - gomod: go.opentelemetry.io/collector/receiver/otlpreceiver v0.104.0 - gomod: - github.com/elastic/otel-profiling-agent v0.0.0-20240717140952-d386d2702214 + github.com/elastic/otel-profiling-agent v0.0.0-20240718145131-96917d0e213a import: github.com/elastic/otel-profiling-agent/otel/receiver name: profilingreceiver diff --git a/otel/receiver/config.go b/otel/receiver/config.go index ec2e1d36..de4a4a3e 100644 --- a/otel/receiver/config.go +++ b/otel/receiver/config.go @@ -32,7 +32,6 @@ type Config struct { MonitorInterval time.Duration `mapstructure:"monitor-interval"` SamplesPerSecond int `mapstructure:"samples-per-second"` SendErrorFrames bool `mapstructure:"send-error-frames"` - OTLPReporter bool `mapstructure:"otlp-reporter"` // Written in createDefaultConfig() PresentCPUCores uint16 diff --git a/otel/receiver/trace-receiver.go b/otel/receiver/trace-receiver.go index 497e1128..8329a6a8 100644 --- a/otel/receiver/trace-receiver.go +++ b/otel/receiver/trace-receiver.go @@ -7,8 +7,9 @@ import ( "time" "github.com/elastic/otel-profiling-agent/containermetadata" - "github.com/elastic/otel-profiling-agent/host" + hostinfo "github.com/elastic/otel-profiling-agent/host" "github.com/elastic/otel-profiling-agent/hostmetadata" + agentmeta "github.com/elastic/otel-profiling-agent/hostmetadata/agent" hostmeta "github.com/elastic/otel-profiling-agent/hostmetadata/host" "github.com/elastic/otel-profiling-agent/platform" "github.com/elastic/otel-profiling-agent/reporter" @@ -17,6 +18,7 @@ import ( "github.com/elastic/otel-profiling-agent/tracer" tracertypes "github.com/elastic/otel-profiling-agent/tracer/types" "github.com/elastic/otel-profiling-agent/util" + "github.com/sirupsen/logrus" "go.opentelemetry.io/collector/component" "go.opentelemetry.io/collector/consumer" "go.uber.org/zap" @@ -36,6 +38,14 @@ var ( // Start starts the receiver. func (otelRcvr *otelReceiver) Start(ctx context.Context, host component.Host) error { + cfg := otelRcvr.config + + if cfg.Verbose { + // logrus is used in the agent code, so we need to set the log level here. + // todo: make the logger configurable + logrus.SetLevel(logrus.DebugLevel) + } + log := otelRcvr.logger.Sugar() otelRcvr.host = host @@ -44,7 +54,13 @@ func (otelRcvr *otelReceiver) Start(ctx context.Context, host component.Host) er } ctx, otelRcvr.cancel = context.WithCancel(ctx) - cfg := otelRcvr.config + if err := tracer.ProbeBPFSyscall(); err != nil { + return fmt.Errorf("failed to probe eBPF syscall: %v", err) + } + + if err := tracer.ProbeTracepoint(); err != nil { + return fmt.Errorf("failed to probe tracepoint: %v", err) + } log.Debug("Determining tracers to include") includeTracers, err := tracertypes.Parse(cfg.Tracers) @@ -66,6 +82,11 @@ func (otelRcvr *otelReceiver) Start(ctx context.Context, host component.Host) er metadataCollector := hostmetadata.NewCollector(cfg.CollectionAgent, environment) hostMetadataMap := metadataCollector.GetHostMetadata() + log.Debugf("Collection agent: %s", cfg.CollectionAgent) + agentmeta.SetAgentData(&agentmeta.Config{ + CollectionAgentAddr: cfg.CollectionAgent, + }) + // Connect to the collection agent and start reporting. rep, err := reporter.Start(ctx, &reporter.Config{ CollAgentAddr: cfg.CollectionAgent, @@ -137,6 +158,8 @@ func (otelRcvr *otelReceiver) Start(ctx context.Context, host component.Host) er // This log line is used in our system tests to verify if that the agent has started. // So if you change this log line, update also the system test. log.Info("Attached sched monitor") + log.Infof("cfg: %+v", cfg) + log.Info("intervals: ", intervals) if err := startTraceHandling(ctx, rep, intervals, trc, traceHandlerCacheSize); err != nil { return fmt.Errorf("failed to start trace handling: %v", err) @@ -165,7 +188,7 @@ func (otelRcvr *otelReceiver) Shutdown(_ context.Context) error { func startTraceHandling(ctx context.Context, rep reporter.TraceReporter, intervals *times.Times, trc *tracer.Tracer, cacheSize uint32) error { // Spawn monitors for the various result maps - traceCh := make(chan *host.Trace) + traceCh := make(chan *hostinfo.Trace) if err := trc.StartMapMonitors(ctx, traceCh); err != nil { return fmt.Errorf("failed to start map monitors: %v", err) diff --git a/tracehandler/tracehandler.go b/tracehandler/tracehandler.go index 73dc67a3..1d4d4d9a 100644 --- a/tracehandler/tracehandler.go +++ b/tracehandler/tracehandler.go @@ -135,6 +135,8 @@ func (m *traceHandler) HandleTrace(bpfTrace *host.Trace) { log.Warnf("Failed to determine container info for trace: %v", err) } + log.Infof("HandleTrace: %v %s", bpfTrace.Hash, bpfTrace.Comm) + if !m.reporter.SupportsReportTraceEvent() { // Fast path: if the trace is already known remotely, we just send a counter update. postConvHash, traceKnown := m.bpfTraceCache.Get(bpfTrace.Hash) diff --git a/tracer/events.go b/tracer/events.go index 4a86f560..fb4f12c8 100644 --- a/tracer/events.go +++ b/tracer/events.go @@ -165,15 +165,18 @@ func startPollingPerfEventMonitor(ctx context.Context, perfEventMap *ebpf.Map, break PollLoop } + log.Debug("Polling perf event buffer") // Eagerly read events until the buffer is exhausted. for { if err = eventReader.ReadInto(&data); err != nil { if !errors.Is(err, os.ErrDeadlineExceeded) { readErrorCount.Add(1) } + log.Debugf(" ... %v", err) break } + log.Debugf(" ... %v", data) if data.LostSamples != 0 { lostEventsCount.Add(data.LostSamples) continue diff --git a/tracer/tracer.go b/tracer/tracer.go index 2733be24..b23fbed5 100644 --- a/tracer/tracer.go +++ b/tracer/tracer.go @@ -949,6 +949,7 @@ func (t *Tracer) loadBpfTrace(raw []byte) *host.Trace { func (t *Tracer) StartMapMonitors(ctx context.Context, traceOutChan chan *host.Trace) error { eventMetricCollector := t.startEventMonitor(ctx) + log.Debugf("trace_poll_interval: %v", t.intervals.TracePollInterval()) startPollingPerfEventMonitor(ctx, t.ebpfMaps["trace_events"], t.intervals.TracePollInterval(), t.samplesPerSecond*int(unsafe.Sizeof(C.Trace{})), func(rawTrace []byte) { traceOutChan <- t.loadBpfTrace(rawTrace)