mirror of
https://github.com/1f349/violet.git
synced 2024-11-21 19:01:39 +00:00
Add cpu profiling
This commit is contained in:
parent
6a5be76db3
commit
3141b3bc55
@ -25,17 +25,22 @@ import (
|
|||||||
_ "net/http/pprof"
|
_ "net/http/pprof"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"runtime/pprof"
|
||||||
)
|
)
|
||||||
|
|
||||||
type serveCmd struct{ configPath string }
|
type serveCmd struct {
|
||||||
|
configPath string
|
||||||
|
cpuprofile string
|
||||||
|
}
|
||||||
|
|
||||||
func (s *serveCmd) Name() string { return "serve" }
|
func (s *serveCmd) Name() string { return "serve" }
|
||||||
func (s *serveCmd) Synopsis() string { return "Serve reverse proxy server" }
|
func (s *serveCmd) Synopsis() string { return "Serve reverse proxy server" }
|
||||||
func (s *serveCmd) SetFlags(f *flag.FlagSet) {
|
func (s *serveCmd) SetFlags(f *flag.FlagSet) {
|
||||||
f.StringVar(&s.configPath, "conf", "", "/path/to/config.json : path to the config file")
|
f.StringVar(&s.configPath, "conf", "", "/path/to/config.json : path to the config file")
|
||||||
|
f.StringVar(&s.cpuprofile, "cpuprofile", "", "write cpu profile to file")
|
||||||
}
|
}
|
||||||
func (s *serveCmd) Usage() string {
|
func (s *serveCmd) Usage() string {
|
||||||
return `serve [-conf <config file>]
|
return `serve [-conf <config file>] [-cpuprofile <profile file>]
|
||||||
Serve reverse proxy server using information from config file
|
Serve reverse proxy server using information from config file
|
||||||
`
|
`
|
||||||
}
|
}
|
||||||
@ -43,6 +48,17 @@ func (s *serveCmd) Usage() string {
|
|||||||
func (s *serveCmd) Execute(_ context.Context, _ *flag.FlagSet, _ ...interface{}) subcommands.ExitStatus {
|
func (s *serveCmd) Execute(_ context.Context, _ *flag.FlagSet, _ ...interface{}) subcommands.ExitStatus {
|
||||||
log.Println("[Violet] Starting...")
|
log.Println("[Violet] Starting...")
|
||||||
|
|
||||||
|
// Enable cpu profiling
|
||||||
|
if s.cpuprofile != "" {
|
||||||
|
f, err := os.Create(s.cpuprofile)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
log.Printf("[Violet] CPU profiling enabled, writing to '%s'\n", s.cpuprofile)
|
||||||
|
_ = pprof.StartCPUProfile(f)
|
||||||
|
defer pprof.StopCPUProfile()
|
||||||
|
}
|
||||||
|
|
||||||
if s.configPath == "" {
|
if s.configPath == "" {
|
||||||
log.Println("[Violet] Error: config flag is missing")
|
log.Println("[Violet] Error: config flag is missing")
|
||||||
return subcommands.ExitUsageError
|
return subcommands.ExitUsageError
|
||||||
|
Loading…
Reference in New Issue
Block a user