2023-01-27 21:37:20 +00:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
2021-03-03 18:17:05 +00:00
|
|
|
|
|
|
|
package controlclient
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"compress/gzip"
|
|
|
|
"context"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"time"
|
2022-09-26 18:52:41 +01:00
|
|
|
|
|
|
|
"tailscale.com/util/goroutines"
|
2021-03-03 18:17:05 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
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)
|
2022-09-26 18:52:41 +01:00
|
|
|
zw.Write(goroutines.ScrubbedGoroutineDump())
|
2021-03-03 18:17:05 +00:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|