All Gloo pods ship with optional Prometheus monitoring capabilities.
This functionality is turned off by default, and can be turned on a couple of different ways: through Helm chart install options; and through environment variables.
Helm Chart Options
The first way is via the helm chart. All deployment objects in the helm templates accept an argument
when set to true, start a stats server on the given pod.
For example, to add stats to the Gloo
gateway, when installing with Helm add
helm install gloo/gloo \ --name gloo \ --namespace gloo-system \ --set discovery.deployment.stats=true
Here’s what the resulting
discovery manifest would look like. Note the additions of the
START_STATS_SERVER environment variable.
apiVersion: extensions/v1beta1 kind: Deployment metadata: labels: app: gloo gloo: discovery name: discovery namespace: gloo-system spec: replicas: 1 selector: matchLabels: gloo: discovery template: metadata: labels: gloo: discovery annotations: prometheus.io/path: /metrics prometheus.io/port: "9091" prometheus.io/scrape: "true" spec: containers: - image: "quay.io/solo-io/discovery:0.11.1" imagePullPolicy: Always name: discovery env: - name: POD_NAMESPACE valueFrom: fieldRef: fieldPath: metadata.namespace - name: START_STATS_SERVER value: "true"
This flag will set the
START_STATS_SERVER environment variable to true in the container which will start the stats
server on port
The other method is to manually set the
START_STATS_SERVER=1 in the pod.
Monitoring Gloo with Prometheus
Prometheus has great support for monitoring kubernetes pods. Docs for that can be found here. If the stats are enabled through the Helm chart than the Prometheus annotations are automatically added to the pod spec. And those Prometheus stats are available from the admin page in our pods.
For example, assuming you installed Gloo as previously using Helm, and enabled stats for discovery, you
kubectl port-forward <pod> 9091:9091 those pods (or deployments/services selecting those pods) to access
their admin page as follows.
kubectl --namespace gloo-system port-forward deployment/discovery 9091:9091
And then open http://localhost:9091 for the admin page, including the Prometheus metrics at http://localhost:9091/metrics.