2021-04-29 21:17:54 +05:30
---
stage: Configure
group: Configure
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
---
# Cluster integrations **(FREE)**
GitLab provides several ways to integrate applications to your
Kubernetes cluster.
To enable cluster integrations, first add a Kubernetes cluster to a GitLab
2021-06-08 01:23:25 +05:30
[project ](../project/clusters/add_remove_clusters.md ) or
[group ](../group/clusters/index.md#group-level-kubernetes-clusters ) or
[instance ](../instance/clusters/index.md ).
2021-04-29 21:17:54 +05:30
## Prometheus cluster integration
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/55244) in GitLab 13.11.
You can integrate your Kubernetes cluster with
[Prometheus ](https://prometheus.io/ ) for monitoring key metrics of your
apps directly from the GitLab UI.
2021-06-08 01:23:25 +05:30
[Alerts ](../../operations/metrics/alerts.md ) can be configured the same way as
for [external Prometheus instances ](../../operations/metrics/alerts.md#external-prometheus-instances ).
Once enabled, you can see metrics from services available in the
2021-04-29 21:17:54 +05:30
[metrics library ](../project/integrations/prometheus_library/index.md ).
2021-06-08 01:23:25 +05:30
### Prometheus Prerequisites
2021-04-29 21:17:54 +05:30
2021-06-08 01:23:25 +05:30
To use this integration:
2021-04-29 21:17:54 +05:30
2021-06-08 01:23:25 +05:30
1. Prometheus must be installed in your cluster in the `gitlab-managed-apps` namespace.
2021-04-29 21:17:54 +05:30
1. The `Service` resource for Prometheus must be named `prometheus-prometheus-server` .
2021-06-08 01:23:25 +05:30
You can manage your Prometheus however you like, but as an example, you can set
it up using [Helm ](https://helm.sh/ ) as follows:
2021-04-29 21:17:54 +05:30
```shell
2021-06-08 01:23:25 +05:30
# Create the required Kubernetes namespace
2021-04-29 21:17:54 +05:30
kubectl create ns gitlab-managed-apps
# Download Helm chart values that is compatible with the requirements above.
2021-06-08 01:23:25 +05:30
# You should substitute the tag that corresponds to the GitLab version in the URL
2021-04-29 21:17:54 +05:30
# - https://gitlab.com/gitlab-org/gitlab/-/raw/<tag>/vendor/prometheus/values.yaml
#
wget https://gitlab.com/gitlab-org/gitlab/-/raw/v13.9.0-ee/vendor/prometheus/values.yaml
2021-06-08 01:23:25 +05:30
# Add the Prometheus community Helm chart repository
2021-04-29 21:17:54 +05:30
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
# Install Prometheus
helm install prometheus prometheus-community/prometheus -n gitlab-managed-apps --values values.yaml
```
Alternatively, you can use your preferred installation method to install
Prometheus as long as you meet the requirements above.
### Enable Prometheus integration for your cluster
To enable the Prometheus integration for your cluster:
1. Go to the cluster's page:
- For a [project-level cluster ](../project/clusters/index.md ), navigate to your project's
**Operations > Kubernetes** .
- For a [group-level cluster ](../group/clusters/index.md ), navigate to your group's
**Kubernetes** page.
2021-06-08 01:23:25 +05:30
- For an [instance-level cluster ](../instance/clusters/index.md ), navigate to your instance's
**Kubernetes** page.
1. Select the **Integrations** tab.
1. Check the **Enable Prometheus integration** checkbox.
1. Click **Save changes** .
1. Go to the **Health** tab to see your cluster's metrics.
## Elastic Stack cluster integration
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/61077) in GitLab 13.12.
You can integrate your cluster with [Elastic
Stack](https://www.elastic.co/elastic-stack) to index and [query your pod
logs](../project/clusters/kubernetes_pod_logs.md).
### Elastic Stack Prerequisites
To use this integration:
1. Elasticsearch 7.x or must be installed in your cluster in the
`gitlab-managed-apps` namespace.
1. The `Service` resource must be called `elastic-stack-elasticsearch-master`
and expose the Elasticsearch API on port `9200` .
1. The logs are expected to be [Filebeat container logs ](https://www.elastic.co/guide/en/beats/filebeat/7.x/filebeat-input-container.html )
following the [7.x log structure ](https://www.elastic.co/guide/en/beats/filebeat/7.x/exported-fields-log.html )
and include [Kubernetes metadata ](https://www.elastic.co/guide/en/beats/filebeat/7.x/add-kubernetes-metadata.html ).
You can manage your Elastic Stack however you like, but as an example, you can
use [this Elastic Stack chart ](https://gitlab.com/gitlab-org/charts/elastic-stack ) to get up and
running:
```shell
# Create the required Kubernetes namespace
kubectl create namespace gitlab-managed-apps
# Download Helm chart values that is compatible with the requirements above.
# You should substitute the tag that corresponds to the GitLab version in the URL
# - https://gitlab.com/gitlab-org/gitlab/-/raw/<tag>/vendor/elastic_stack/values.yaml
#
wget https://gitlab.com/gitlab-org/gitlab/-/raw/v13.9.0-ee/vendor/elastic_stack/values.yaml
# Add the GitLab Helm chart repository
helm repo add gitlab https://charts.gitlab.io
# Install Elastic Stack
helm install prometheus gitlab/elastic-stack -n gitlab-managed-apps --values values.yaml
```
### Enable Elastic Stack integration for your cluster
To enable the Elastic Stack integration for your cluster:
1. Go to the cluster's page:
- For a [project-level cluster ](../project/clusters/index.md ), navigate to your project's
**Operations > Kubernetes** .
- For a [group-level cluster ](../group/clusters/index.md ), navigate to your group's
**Kubernetes** page.
- For an [instance-level cluster ](../instance/clusters/index.md ), navigate to your instance's
**Kubernetes** page.
2021-04-29 21:17:54 +05:30
1. Select the **Integrations** tab.
1. Check the **Enable Prometheus integration** checkbox.
1. Click **Save changes** .
1. Go to the **Health** tab to see your cluster's metrics.