mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-11 05:53:43 +00:00
c8e2a3bd49
# Which Problems Are Solved To have more insight on the performance, CPU and memory usage of ZITADEL, we want to enable profiling. # How the Problems Are Solved - Allow profiling by configuration. - Provide Google Cloud Profiler as first implementation # Additional Changes None. # Additional Context There were possible memory leaks reported: https://discord.com/channels/927474939156643850/1273210227918897152 Co-authored-by: Silvan <silvan.reusser@gmail.com>
31 lines
636 B
Go
31 lines
636 B
Go
package config
|
|
|
|
import (
|
|
"github.com/zitadel/zitadel/internal/telemetry/profiler/google"
|
|
"github.com/zitadel/zitadel/internal/zerrors"
|
|
)
|
|
|
|
type Config struct {
|
|
Type string
|
|
Config map[string]interface{} `mapstructure:",remain"`
|
|
}
|
|
|
|
var profiler = map[string]func(map[string]interface{}) error{
|
|
"google": google.NewProfiler,
|
|
"none": NoProfiler,
|
|
"": NoProfiler,
|
|
}
|
|
|
|
func (c *Config) NewProfiler() error {
|
|
t, ok := profiler[c.Type]
|
|
if !ok {
|
|
return zerrors.ThrowInternalf(nil, "PROFI-Dfqsx", "config type %s not supported", c.Type)
|
|
}
|
|
|
|
return t(c.Config)
|
|
}
|
|
|
|
func NoProfiler(_ map[string]interface{}) error {
|
|
return nil
|
|
}
|