Skip to content

Commit

Permalink
Refactor metrics code
Browse files Browse the repository at this point in the history
  • Loading branch information
sgayangi committed Mar 18, 2024
1 parent 1fb0c6c commit d48e51a
Show file tree
Hide file tree
Showing 10 changed files with 54 additions and 45 deletions.
4 changes: 2 additions & 2 deletions adapter/config/default_config.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ var defaultConfig = &Config{
Namespaces: nil,
},
Environment: "Default",
Metrics: metrics{
Metrics: Metrics{
Enabled: false,
Type: "prometheus",
Port: 18006,
Expand Down Expand Up @@ -192,7 +192,7 @@ var defaultConfig = &Config{
MaximumSize: 10000,
ExpiryTime: 15,
},
Metrics: metrics{
Metrics: Metrics{
Enabled: false,
Type: "azure",
},
Expand Down
7 changes: 4 additions & 3 deletions adapter/config/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ type adapter struct {
// Environment of the Adapter
Environment string
// Metric represents configurations to expose/export go metrics
Metrics metrics
Metrics Metrics
}

// Envoy Listener Component related configurations.
Expand Down Expand Up @@ -159,7 +159,7 @@ type enforcer struct {
Management management
RestServer restServer
Filters []filter
Metrics metrics
Metrics Metrics
MandateSubscriptionValidation bool
Client httpClient
}
Expand Down Expand Up @@ -300,7 +300,8 @@ type tracing struct {
ConfigProperties map[string]string
}

type metrics struct {
// Metrics defines the configuration for metrics collection.
type Metrics struct {
Enabled bool
Type string
Port int32
Expand Down
11 changes: 1 addition & 10 deletions adapter/internal/adapter/adapter.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,22 +20,19 @@ package adapter

import (
"crypto/tls"
"strings"
"time"

discoveryv3 "github.com/envoyproxy/go-control-plane/envoy/service/discovery/v3"
xdsv3 "github.com/envoyproxy/go-control-plane/pkg/server/v3"
enforcerCallbacks "github.com/wso2/apk/adapter/internal/discovery/xds/enforcercallbacks"
routercb "github.com/wso2/apk/adapter/internal/discovery/xds/routercallbacks"
"github.com/wso2/apk/adapter/internal/loggers"
"github.com/wso2/apk/adapter/internal/operator"
apiservice "github.com/wso2/apk/adapter/pkg/discovery/api/wso2/discovery/service/api"
configservice "github.com/wso2/apk/adapter/pkg/discovery/api/wso2/discovery/service/config"
subscriptionservice "github.com/wso2/apk/adapter/pkg/discovery/api/wso2/discovery/service/subscription"
wso2_server "github.com/wso2/apk/adapter/pkg/discovery/protocol/server/v3"
"github.com/wso2/apk/adapter/pkg/health"
healthservice "github.com/wso2/apk/adapter/pkg/health/api/wso2/health/service"
"github.com/wso2/apk/adapter/pkg/metrics"
"github.com/wso2/apk/adapter/pkg/utils/tlsutils"

"context"
Expand Down Expand Up @@ -183,13 +180,7 @@ func Run(conf *config.Config) {
// Set enforcer startup configs
xds.UpdateEnforcerConfig(conf)

go operator.InitOperator(conf.Adapter.Metrics.Port)

// Start the metrics server
if conf.Adapter.Metrics.Enabled && strings.EqualFold(conf.Adapter.Metrics.Type, metrics.PrometheusMetricType) {
loggers.LoggerAPKOperator.Info("Starting Prometheus Metrics Server ....")
go metrics.StartPrometheusMetricsServer()
}
go operator.InitOperator(conf.Adapter.Metrics)

OUTER:
for {
Expand Down
25 changes: 18 additions & 7 deletions adapter/internal/operator/operator.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,14 @@ package operator

import (
"flag"
"strconv"
"fmt"
"strings"

"github.com/wso2/apk/adapter/config"
"github.com/wso2/apk/adapter/internal/loggers"

"github.com/wso2/apk/adapter/pkg/logging"
"github.com/wso2/apk/adapter/pkg/metrics"
gwapiv1a2 "sigs.k8s.io/gateway-api/apis/v1alpha2"
gwapiv1b1 "sigs.k8s.io/gateway-api/apis/v1beta1"

Expand Down Expand Up @@ -68,12 +70,9 @@ func init() {
}

// InitOperator starts the Kubernetes gateway operator
func InitOperator(prometheusPort int32) {
var metricsAddr string
func InitOperator(metricsConfig config.Metrics) {
var enableLeaderElection bool
var probeAddr string
port := strconv.FormatInt(int64(prometheusPort), 10)
flag.StringVar(&metricsAddr, "metrics-bind-address", ":"+port, "The address the metric endpoint binds to.")
flag.StringVar(&probeAddr, "health-probe-bind-address", ":8081", "The address the probe endpoint binds to.")
flag.BoolVar(&enableLeaderElection, "leader-elect", false,
"Enable leader election for controller manager. "+
Expand All @@ -87,7 +86,7 @@ func InitOperator(prometheusPort int32) {

operatorDataStore := synchronizer.GetOperatorDataStore()

mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{
options := ctrl.Options{
Scheme: scheme,
HealthProbeBindAddress: probeAddr,
LeaderElection: true,
Expand All @@ -104,7 +103,13 @@ func InitOperator(prometheusPort int32) {
// if you are doing or is intended to do any operation such as perform cleanups
// after the manager stops then its usage might be unsafe.
// LeaderElectionReleaseOnCancel: true,
})
}

if metricsConfig.Enabled {
options.MetricsBindAddress = fmt.Sprintf(":%d", metricsConfig.Port)
}

mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), options)

if err != nil {
loggers.LoggerAPKOperator.ErrorC(logging.PrintError(logging.Error2600, logging.BLOCKER, "Unable to start manager: %v", err))
Expand Down Expand Up @@ -138,6 +143,12 @@ func InitOperator(prometheusPort int32) {
loggers.LoggerAPKOperator.ErrorC(logging.PrintError(logging.Error2603, logging.BLOCKER, "Unable to set up ready check: %v", err))
}

// Register the metrics collector
if metricsConfig.Enabled && strings.EqualFold(metricsConfig.Type, metrics.PrometheusMetricType) {
loggers.LoggerAPKOperator.Info("Starting Prometheus Metrics Server ....")
go metrics.RegisterPrometheusCollector()
}

go synchronizer.HandleAPILifeCycleEvents(&ch, &successChannel)
go synchronizer.HandleGatewayLifeCycleEvents(&gatewaych)
if config.ReadConfigs().PartitionServer.Enabled {
Expand Down
4 changes: 2 additions & 2 deletions adapter/pkg/metrics/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,8 +87,8 @@ func (collector *AdapterCollector) Collect(ch chan<- prometheus.Metric) {
ch <- prometheus.MustNewConstMetric(collector.internalClusterCount, prometheus.GaugeValue, internalClusterCount)
}

// StartPrometheusMetricsServer initializes and starts the metrics server to expose metrics to prometheus.
func StartPrometheusMetricsServer() {
// RegisterPrometheusCollector registers the Prometheus collector for metrics.
func RegisterPrometheusCollector() {

collector := adapterMetricsCollector()
k8smetrics.Registry.MustRegister(collector)
Expand Down
10 changes: 1 addition & 9 deletions common-controller/commoncontroller/common_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ import (
"net"
"os"
"os/signal"
"strings"
"time"

corev3 "github.com/envoyproxy/go-control-plane/envoy/config/core/v3"
Expand All @@ -41,7 +40,6 @@ import (
"github.com/wso2/apk/common-controller/internal/server"
utils "github.com/wso2/apk/common-controller/internal/utils"
xds "github.com/wso2/apk/common-controller/internal/xds"
"github.com/wso2/apk/common-controller/pkg/metrics"
apkmgt "github.com/wso2/apk/common-go-libs/pkg/discovery/api/wso2/discovery/service/apkmgt"
"google.golang.org/grpc"
"google.golang.org/grpc/credentials"
Expand Down Expand Up @@ -219,13 +217,7 @@ func InitCommonControllerServer(conf *config.Config) {
// Start Enforcer xDS gRPC server
runCommonEnforcerServer(port)

go operator.InitOperator(conf.CommonController.Metrics.Port)

// Start the metrics server
if conf.CommonController.Metrics.Enabled && strings.EqualFold(conf.CommonController.Metrics.Type, metrics.PrometheusMetricType) {
loggers.LoggerAPKOperator.Info("Starting Prometheus Metrics Server ....")
go metrics.StartPrometheusMetricsServer()
}
go operator.InitOperator(conf.CommonController.Metrics)

OUTER:
for {
Expand Down
2 changes: 1 addition & 1 deletion common-controller/internal/config/default_config.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ var defaultConfig = &Config{
RetryInterval: 5,
Persistence: persistence{Type: "K8s"},
},
Metrics: metrics{
Metrics: Metrics{
Enabled: false,
Type: "prometheus",
Port: 18006,
Expand Down
5 changes: 3 additions & 2 deletions common-controller/internal/config/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ type commoncontroller struct {
WebServer webServer
InternalAPIServer internalAPIServer
ControlPlane controlplane
Metrics metrics
Metrics Metrics
Database database
}
type controlplane struct {
Expand Down Expand Up @@ -105,7 +105,8 @@ type webServer struct {
Port int64
}

type metrics struct {
// Metrics defines the configuration for metrics collection.
type Metrics struct {
Enabled bool
Type string
Port int32
Expand Down
27 changes: 20 additions & 7 deletions common-controller/internal/operator/operator.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,9 @@ package operator

import (
"flag"
"fmt"
"os"
"strconv"
"strings"

// Import all Kubernetes client auth plugins (e.g. Azure, GCP, OIDC, etc.)
// to ensure that exec-entrypoint and run can make use of them.
Expand All @@ -34,6 +35,7 @@ import (
"github.com/wso2/apk/common-controller/internal/loggers"
cpcontrollers "github.com/wso2/apk/common-controller/internal/operator/controllers/cp"
dpcontrollers "github.com/wso2/apk/common-controller/internal/operator/controllers/dp"
"github.com/wso2/apk/common-controller/pkg/metrics"
cpv1alpha2 "github.com/wso2/apk/common-go-libs/apis/cp/v1alpha2"
dpv1alpha1 "github.com/wso2/apk/common-go-libs/apis/dp/v1alpha1"
dpv1alpha2 "github.com/wso2/apk/common-go-libs/apis/dp/v1alpha2"
Expand Down Expand Up @@ -65,13 +67,11 @@ func init() {
}

// InitOperator initializes the operator
func InitOperator(prometheusPort int32) {
var metricsAddr string
// func InitOperator(prometheusPort int32, metricsEnabled bool) {
func InitOperator(metricsConfig config.Metrics) {
var enableLeaderElection bool
var probeAddr string
controlPlaneID := uuid.New().String()
port := strconv.FormatInt(int64(prometheusPort), 10)
flag.StringVar(&metricsAddr, "metrics-bind-address", ":"+port, "The address the metric endpoint binds to.")
flag.StringVar(&probeAddr, "health-probe-bind-address", ":8081", "The address the probe endpoint binds to.")
flag.BoolVar(&enableLeaderElection, "leader-elect", false,
"Enable leader election for controller manager. "+
Expand All @@ -85,7 +85,8 @@ func InitOperator(prometheusPort int32) {
ctrl.SetLogger(zap.New(zap.UseFlagOptions(&opts)))
ratelimitStore := cache.CreateNewOperatorDataStore()
subscriptionStore := cache.CreateNewSubscriptionDataStore()
mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{

options := ctrl.Options{
Scheme: scheme,
HealthProbeBindAddress: probeAddr,
// LeaderElection: true,
Expand All @@ -101,7 +102,13 @@ func InitOperator(prometheusPort int32) {
// if you are doing or is intended to do any operation such as perform cleanups
// after the manager stops then its usage might be unsafe.
// LeaderElectionReleaseOnCancel: true,
})
}

if metricsConfig.Enabled {
options.MetricsBindAddress = fmt.Sprintf(":%d", metricsConfig.Port)
}

mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), options)
if err != nil {
loggers.LoggerAPKOperator.ErrorC(logging.PrintError(logging.Error2600, logging.BLOCKER, "Unable to start manager: %v", err))
os.Exit(1)
Expand Down Expand Up @@ -199,6 +206,12 @@ func InitOperator(prometheusPort int32) {
}()
}

// Register the metrics collector
if metricsConfig.Enabled && strings.EqualFold(metricsConfig.Type, metrics.PrometheusMetricType) {
loggers.LoggerAPKOperator.Info("Starting Prometheus Metrics Server ....")
go metrics.RegisterPrometheusCollector()
}

setupLog.Info("starting manager")
if err := mgr.Start(ctrl.SetupSignalHandler()); err != nil {
loggers.LoggerAPKOperator.ErrorC(logging.PrintError(logging.Error2604, logging.BLOCKER, "Problem running manager: %v", err))
Expand Down
4 changes: 2 additions & 2 deletions common-controller/pkg/metrics/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,8 @@ import (
k8smetrics "sigs.k8s.io/controller-runtime/pkg/metrics"
)

// StartPrometheusMetricsServer initializes and starts the metrics server to expose metrics to prometheus.
func StartPrometheusMetricsServer() {
// RegisterPrometheusCollector registers the Prometheus collector for metrics.
func RegisterPrometheusCollector() {

collector := metrics.CustomMetricsCollector()
k8smetrics.Registry.MustRegister(collector)
Expand Down

0 comments on commit d48e51a

Please sign in to comment.