forked from kedacore/http-add-on
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathconfig.go
47 lines (43 loc) · 2.39 KB
/
config.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package main
import (
"time"
"github.com/kelseyhightower/envconfig"
)
type config struct {
// GRPCPort is what port to serve the KEDA-compatible gRPC external scaler interface
// on
GRPCPort int `envconfig:"KEDA_HTTP_SCALER_PORT" default:"8080"`
// HealthPort is the port to serve the Kubernetes health check endpoints on
HealthPort int `envconfig:"KEDA_HTTP_HEALTH_PORT" default:"8090"`
// TargetNamespace is the namespace in which this scaler is running, and the namespace
// that the target interceptors are running in. This scaler and all the interceptors
// must be running in the same namespace
TargetNamespace string `envconfig:"KEDA_HTTP_SCALER_TARGET_ADMIN_NAMESPACE" required:"true"`
// TargetService is the name of the service to issue metrics RPC requests to interceptors
TargetService string `envconfig:"KEDA_HTTP_SCALER_TARGET_ADMIN_SERVICE" required:"true"`
// TargetDeployment is the name of the deployment to issue metrics RPC requests to interceptors
TargetDeployment string `envconfig:"KEDA_HTTP_SCALER_TARGET_ADMIN_DEPLOYMENT" required:"true"`
// TargetPort is the port on TargetService to which to issue metrics RPC requests to
// interceptors
TargetPort int `envconfig:"KEDA_HTTP_SCALER_TARGET_ADMIN_PORT" required:"true"`
// TargetPendingRequests is the default value for the
// pending requests value that the scaler will return to
// KEDA, if that value is not set on an incoming
// `HTTPScaledObject`
TargetPendingRequests int `envconfig:"KEDA_HTTP_SCALER_TARGET_PENDING_REQUESTS" default:"100"`
// ConfigMapCacheRsyncPeriod is the time interval
// for the configmap informer to rsync the local cache.
ConfigMapCacheRsyncPeriod time.Duration `envconfig:"KEDA_HTTP_SCALER_CONFIG_MAP_INFORMER_RSYNC_PERIOD" default:"60m"`
// DeploymentCacheRsyncPeriod is the time interval
// for the deployment informer to rsync the local cache.
DeploymentCacheRsyncPeriod time.Duration `envconfig:"KEDA_HTTP_SCALER_DEPLOYMENT_INFORMER_RSYNC_PERIOD" default:"60m"`
// QueueTickDuration is the duration between queue requests
QueueTickDuration time.Duration `envconfig:"KEDA_HTTP_QUEUE_TICK_DURATION" default:"1s"`
// This will be the 'Target Pending Requests' for the interceptor
TargetPendingRequestsInterceptor int `envconfig:"KEDA_HTTP_SCALER_TARGET_PENDING_REQUESTS_INTERCEPTOR" default:"100"`
}
func mustParseConfig() *config {
ret := new(config)
envconfig.MustProcess("", ret)
return ret
}