mirror of
https://github.com/tailscale/tailscale.git
synced 2024-11-27 03:55:36 +00:00
7c1068b7ac
ScrubbedGoroutineDump previously only returned the stacks of all goroutines. I also want to be able to use this for only the current goroutine's stack. Add a bool param to support both ways. Updates tailscale/corp#5149 Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
41 lines
946 B
Go
41 lines
946 B
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package controlclient
|
|
|
|
import (
|
|
"bytes"
|
|
"compress/gzip"
|
|
"context"
|
|
"log"
|
|
"net/http"
|
|
"time"
|
|
|
|
"tailscale.com/util/goroutines"
|
|
)
|
|
|
|
func dumpGoroutinesToURL(c *http.Client, targetURL string) {
|
|
ctx, cancel := context.WithTimeout(context.Background(), 15*time.Second)
|
|
defer cancel()
|
|
|
|
zbuf := new(bytes.Buffer)
|
|
zw := gzip.NewWriter(zbuf)
|
|
zw.Write(goroutines.ScrubbedGoroutineDump(true))
|
|
zw.Close()
|
|
|
|
req, err := http.NewRequestWithContext(ctx, "PUT", targetURL, zbuf)
|
|
if err != nil {
|
|
log.Printf("dumpGoroutinesToURL: %v", err)
|
|
return
|
|
}
|
|
req.Header.Set("Content-Encoding", "gzip")
|
|
t0 := time.Now()
|
|
_, err = c.Do(req)
|
|
d := time.Since(t0).Round(time.Millisecond)
|
|
if err != nil {
|
|
log.Printf("dumpGoroutinesToURL error: %v to %v (after %v)", err, targetURL, d)
|
|
} else {
|
|
log.Printf("dumpGoroutinesToURL complete to %v (after %v)", targetURL, d)
|
|
}
|
|
}
|