2020-08-17 09:48:12 +00:00
|
|
|
package cli
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
"golang.org/x/xerrors"
|
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/node/repo"
|
|
|
|
manet "github.com/multiformats/go-multiaddr-net"
|
|
|
|
)
|
|
|
|
|
|
|
|
var pprofCmd = &cli.Command{
|
2020-08-18 16:27:28 +00:00
|
|
|
Name: "pprof",
|
2020-08-17 09:48:12 +00:00
|
|
|
Hidden: true,
|
|
|
|
Subcommands: []*cli.Command{
|
|
|
|
PprofGoroutines,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var PprofGoroutines = &cli.Command{
|
|
|
|
Name: "goroutines",
|
|
|
|
Usage: "Get goroutine stacks",
|
|
|
|
Action: func(cctx *cli.Context) error {
|
|
|
|
ti, ok := cctx.App.Metadata["repoType"]
|
|
|
|
if !ok {
|
|
|
|
log.Errorf("unknown repo type, are you sure you want to use GetAPI?")
|
|
|
|
ti = repo.FullNode
|
|
|
|
}
|
|
|
|
t, ok := ti.(repo.RepoType)
|
|
|
|
if !ok {
|
|
|
|
log.Errorf("repoType type does not match the type of repo.RepoType")
|
|
|
|
}
|
|
|
|
ainfo, err := GetAPIInfo(cctx, t)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("could not get API info: %w", err)
|
|
|
|
}
|
|
|
|
_, addr, err := manet.DialArgs(ainfo.Addr)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-18 16:27:28 +00:00
|
|
|
addr = "http://" + addr + "/debug/pprof/goroutine?debug=2"
|
2020-08-17 09:48:12 +00:00
|
|
|
|
2020-08-20 04:49:10 +00:00
|
|
|
r, err := http.Get(addr) //nolint:gosec
|
2020-08-17 09:48:12 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.Copy(os.Stdout, r.Body); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return r.Body.Close()
|
|
|
|
},
|
|
|
|
}
|