Skip to content

Commit

Permalink
Deprecate pprof feature; Fix request sending bug (#104)
Browse files Browse the repository at this point in the history
Signed-off-by: Saswata Mukherjee <saswataminsta@yahoo.com>
  • Loading branch information
saswatamcode authored Oct 21, 2024
1 parent 5d86b52 commit 6246210
Show file tree
Hide file tree
Showing 3 changed files with 1 addition and 122 deletions.
45 changes: 0 additions & 45 deletions cmd/avalanche/avalanche.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,9 @@ import (
"crypto/tls"
"fmt"
"log"
"math/rand"
"net/http"
"os"
"strconv"
"sync"
"syscall"
"time"

"github.com/nelkinda/health-go"
"github.com/oklog/run"
Expand All @@ -34,7 +30,6 @@ import (
"gopkg.in/alecthomas/kingpin.v2"

"github.com/prometheus-community/avalanche/metrics"
"github.com/prometheus-community/avalanche/pkg/download"
)

func main() {
Expand Down Expand Up @@ -68,9 +63,6 @@ func main() {
cfg := metrics.NewConfigFromFlags(kingpin.Flag)
port := kingpin.Flag("port", "Port to serve at").Default("9001").Int()
remoteURL := kingpin.Flag("remote-url", "URL to send samples via remote_write API.").URL()
// TODO(bwplotka): Kill pprof feature, you can install OSS continuous profiling easily instead.
remotePprofURLs := kingpin.Flag("remote-pprof-urls", "a list of urls to download pprofs during the remote write: --remote-pprof-urls=http://127.0.0.1:10902/debug/pprof/heap --remote-pprof-urls=http://127.0.0.1:10902/debug/pprof/profile").URLList()
remotePprofInterval := kingpin.Flag("remote-pprof-interval", "how often to download pprof profiles. When not provided it will download a profile once before the end of the test.").Duration()
remoteConcurrencyLimit := kingpin.Flag("remote-concurrency-limit", "how many concurrent writes can happen at any given time").Default("20").Int()
remoteBatchSize := kingpin.Flag("remote-batch-size", "how many samples to send with each remote_write API request.").Default("2000").Int()
remoteRequestCount := kingpin.Flag("remote-requests-count", "How many requests to send in total to the remote_write API. Set to -1 to run indefinitely.").Default("100").Int()
Expand Down Expand Up @@ -119,48 +111,11 @@ func main() {
OutOfOrder: *outOfOrder,
}

// Collect Pprof during the write only if not collecting within a regular interval.
if *remotePprofInterval == 0 {
config.PprofURLs = *remotePprofURLs
}

var (
wg sync.WaitGroup
done = make(chan struct{})
)
if *remotePprofInterval > 0 {
if len(*remotePprofURLs) == 0 {
log.Fatal("remote profiling interval specified without any remote pprof urls")
}
suffix := rand.Intn(1000)
go func() {
ticker := time.NewTicker(*remotePprofInterval)
var dur time.Duration
loop:
for {
<-ticker.C
select {
case <-done: // Prevents a panic when calling wg.Add(1) after calling wg.Wait().
break loop
default:
}
dur += *remotePprofInterval
wg.Add(1)
download.URLs(*remotePprofURLs, strconv.Itoa(suffix)+"-"+dur.String())
wg.Done()
}
}()
}

ctx, cancel := context.WithCancel(context.Background())
g.Add(func() error {
if err := metrics.SendRemoteWrite(ctx, config, reg); err != nil {
return err
}
if *remotePprofInterval > 0 {
done <- struct{}{}
wg.Wait()
}
return nil // One-off.
}, func(error) { cancel() })
}
Expand Down
14 changes: 1 addition & 13 deletions metrics/write.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import (
"sync"
"time"

"github.com/prometheus-community/avalanche/pkg/download"
"github.com/prometheus-community/avalanche/pkg/errors"

"github.com/gogo/protobuf/proto"
Expand Down Expand Up @@ -129,7 +128,6 @@ func (c *Client) write(ctx context.Context) error {
totalSamplesAct int
mtx sync.Mutex
wgMetrics sync.WaitGroup
wgPprof sync.WaitGroup
merr = &errors.MultiError{}
)

Expand All @@ -153,19 +151,10 @@ func (c *Client) write(ctx context.Context) error {
}

if !shouldRunForever {
if i < c.config.RequestCount {
if i >= c.config.RequestCount {
break
}
i++
// Download the pprofs during half of the iteration to get avarege readings.
// Do that only when it is not set to take profiles at a given interval.
if len(c.config.PprofURLs) > 0 && i == c.config.RequestCount/2 {
wgPprof.Add(1)
go func() {
download.URLs(c.config.PprofURLs, time.Now().Format("2-Jan-2006-15:04:05"))
wgPprof.Done()
}()
}
}

<-ticker.C
Expand Down Expand Up @@ -212,7 +201,6 @@ func (c *Client) write(ctx context.Context) error {
return merr.Err()
}
}
wgPprof.Wait()
if c.config.RequestCount*len(tss) != totalSamplesAct {
merr.Add(fmt.Errorf("total samples mismatch, exp:%v , act:%v", totalSamplesExp, totalSamplesAct))
}
Expand Down
64 changes: 0 additions & 64 deletions pkg/download/download.go

This file was deleted.

0 comments on commit 6246210

Please sign in to comment.