Skip to content

Commit

Permalink
Add an option to expose Prometheus metrics via http/s server
Browse files Browse the repository at this point in the history
Signed-off-by: Botond Szirtes <[email protected]>
  • Loading branch information
bszirtes committed Aug 14, 2024
1 parent c0bcf88 commit b9fa637
Show file tree
Hide file tree
Showing 4 changed files with 116 additions and 1 deletion.
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ require (
github.com/networkservicemesh/api v1.13.1-0.20240424210452-d0df98851760
github.com/open-policy-agent/opa v0.44.0
github.com/pkg/errors v0.9.1
github.com/prometheus/client_golang v1.17.0
github.com/r3labs/diff v1.1.0
github.com/sirupsen/logrus v1.9.0
github.com/spiffe/go-spiffe/v2 v2.1.7
Expand Down Expand Up @@ -85,7 +86,6 @@ require (
github.com/nats-io/nuid v1.0.1 // indirect
github.com/openzipkin/zipkin-go v0.4.2 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
github.com/prometheus/client_golang v1.17.0 // indirect
github.com/prometheus/client_model v0.5.0 // indirect
github.com/prometheus/common v0.44.0 // indirect
github.com/prometheus/procfs v0.11.1 // indirect
Expand Down
2 changes: 2 additions & 0 deletions pkg/tools/opentelemetry/opentelemetry.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
//
// Copyright (c) 2023 Cisco and/or its affiliates.
//
// Copyright (c) 2024 Nordix Foundation.
//
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License");
Expand Down
35 changes: 35 additions & 0 deletions pkg/tools/prometheus/prometheus.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// Copyright (c) 2024 Nordix Foundation.
//
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

// Package prometheus provides a set of utilities for assisting with Prometheus data
package prometheus

import (
"os"
"strconv"
)

const (
prometheusEnv = "PROMETHEUS"
)

// IsEnabled returns true if prometheus is enabled
func IsEnabled() bool {
if v, err := strconv.ParseBool(os.Getenv(prometheusEnv)); err == nil {
return v
}
return false
}
78 changes: 78 additions & 0 deletions pkg/tools/prometheus/server.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
// Copyright (c) 2024 Nordix Foundation.
//
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

// Package prometheus provides a set of utilities for assisting with Prometheus data
package prometheus

import (
"context"
"crypto/tls"
"fmt"
"net/http"
"time"

"github.com/pkg/errors"
"github.com/prometheus/client_golang/prometheus/promhttp"

"github.com/networkservicemesh/sdk/pkg/tools/log"
)

// Server is a server type for handling requests
type Server struct {
TLSConfig *tls.Config
IP string
Port int
HeaderTimeout time.Duration
}

// Start initiates the server to begin handling incoming requests
func (s *Server) Start(ctx context.Context) error {
log.FromContext(ctx).Info("Start metrics server", "ip", s.IP, "port", s.Port)

server := &http.Server{
Addr: fmt.Sprintf("%s:%d", s.IP, s.Port),
TLSConfig: s.TLSConfig,
ReadHeaderTimeout: s.HeaderTimeout,
}

http.Handle("/metrics", promhttp.Handler())

serverCtx, cancel := context.WithCancel(ctx)
var ListenAndServeErr error

go func() {
ListenAndServeErr = server.ListenAndServeTLS("", "")
if ListenAndServeErr != nil {
cancel()
}
}()

<-serverCtx.Done()

if ListenAndServeErr != nil {
return errors.Errorf("failed to ListenAndServe on metrics server: %s", ListenAndServeErr)
}

shutdownCtx, shutdownCancel := context.WithTimeout(context.Background(), 1*time.Second)
defer shutdownCancel()

err := server.Shutdown(shutdownCtx)
if err != nil {
return errors.Errorf("failed to shutdown metrics server: %s", err)
}

return nil
}

0 comments on commit b9fa637

Please sign in to comment.