Add an option --pprof

Former-commit-id: 3ca1280e8daddbf1075e3189f9851211ce8882ae
This commit is contained in:
2023-03-28 20:07:26 +07:00
parent 988ae79989
commit e863dc456a
3 changed files with 24 additions and 9 deletions

View File

@ -2,8 +2,10 @@ package main
import (
"os"
log "github.com/sirupsen/logrus"
"git.metabarcoding.org/lecasofts/go/obitools/pkg/obiiter"
"git.metabarcoding.org/lecasofts/go/obitools/pkg/obioptions"
"git.metabarcoding.org/lecasofts/go/obitools/pkg/obitools/obiconvert"
@ -12,13 +14,9 @@ import (
func main() {
// go tool pprof -http=":8000" ./obipairing ./cpu.pprof
// f, err := os.Create("cpu.pprof")
// if err != nil {
// log.Fatal(err)
// }
// pprof.StartCPUProfile(f)
// defer pprof.StopCPUProfile()
// go tool pprof -nodefraction=0 -http=:8081 http://localhost:8080/debug/pprof/allocs
// look at http://localhost:8080/debug/pprof for havng the possibilities
//go http.ListenAndServe("localhost:8080", nil)
// go tool trace cpu.trace
// ftrace, err := os.Create("cpu.trace")

View File

@ -8,12 +8,17 @@ import (
log "github.com/sirupsen/logrus"
"github.com/DavidGamba/go-getoptions"
"net/http"
_ "net/http/pprof"
)
var _Debug = false
var _ParallelWorkers = runtime.NumCPU()*2 - 1
var _MaxAllowedCPU = runtime.NumCPU()
var _BatchSize = 5000
var _Pprof = false
type ArgumentParser func([]string) (*getoptions.GetOpt, []string)
@ -24,6 +29,7 @@ func GenerateOptionParser(optionset ...func(*getoptions.GetOpt)) ArgumentParser
options.SetUnknownMode(getoptions.Fail)
options.Bool("help", false, options.Alias("h", "?"))
options.BoolVar(&_Debug, "debug", false)
options.BoolVar(&_Pprof, "pprof", false)
options.IntVar(&_ParallelWorkers, "workers", _ParallelWorkers,
options.Alias("w"),
@ -52,6 +58,11 @@ func GenerateOptionParser(optionset ...func(*getoptions.GetOpt)) ArgumentParser
log.Debugln("Switch to debug level logging")
}
if options.Called("pprof") {
go http.ListenAndServe("localhost:8080", nil)
log.Infoln("Start a pprof server at address http://localhost:8080/debug/pprof")
}
// Handle user errors
if err != nil {
fmt.Fprintf(os.Stderr, "ERROR: %s\n\n", err)

View File

@ -45,7 +45,13 @@ func GetSlice(capacity int) []byte {
}
func CopySlice(src []byte) []byte {
sl := GetSlice(len(src))[0:len(src)]
sl := GetSlice(len(src))
if cap(sl) < len(src) {
log.Panicln("Bizarre... j'aurai pourtant cru")
}
sl = sl[0:len(src)]
copy(sl, src)