mirror of
https://github.com/kyverno/kyverno.git
synced 2024-12-14 11:57:48 +00:00
4bdd45c0cc
* refactor: introduce cmd internal package Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * fix Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * changelog Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * informer Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * tracing Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * fix flag Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> Signed-off-by: Charles-Edouard Brétéché <charled.breteche@gmail.com>
26 lines
609 B
Go
26 lines
609 B
Go
package profiling
|
|
|
|
import (
|
|
"net/http"
|
|
_ "net/http/pprof" // #nosec
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/go-logr/logr"
|
|
"github.com/kyverno/kyverno/pkg/logging"
|
|
)
|
|
|
|
func Start(logger logr.Logger, address string) {
|
|
logger.Info("Enable profiling, see details at https://github.com/kyverno/kyverno/wiki/Profiling-Kyverno-on-Kubernetes")
|
|
go func() {
|
|
s := http.Server{
|
|
Addr: address,
|
|
ErrorLog: logging.StdLogger(logger, ""),
|
|
ReadHeaderTimeout: 30 * time.Second,
|
|
}
|
|
if err := s.ListenAndServe(); err != nil {
|
|
logger.Error(err, "failed to enable profiling")
|
|
os.Exit(1)
|
|
}
|
|
}()
|
|
}
|