Difference between revisions of "Deploy Prometheus Monitoring with Prometheus Operator"

From epsciwiki
Jump to navigation Jump to search
(Created page with "= Deploy Prometheus Monitoring with Prometheus Operator = This guide outlines the deployment process for a custom Prometheus monitoring setup using the Prometheus Operator....")
 
Line 11: Line 11:
 
# [https://helm.sh/docs/intro/install/ Helm]
 
# [https://helm.sh/docs/intro/install/ Helm]
  
== Deployment Steps ==
+
== Deployment Flow Chart ==
  
=== Install Prometheus Operator ===
+
Below is a visual representation of the Prometheus deployment process:
First, we need to install the Prometheus Operator:
 
  
a. Create a namespace for monitoring:
+
[[File: prometheus_deployment_flow_chart.png|Prometheus Deployment Flow Chart|1000px]]
<syntaxhighlight lang="bash">
 
kubectl create namespace monitoring
 
</syntaxhighlight>
 
  
b. Add the Prometheus Operator Helm repository:
+
This flow chart illustrates the key steps in deploying Prometheus monitoring using the Prometheus Operator.
<syntaxhighlight lang="bash">
 
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
 
helm repo update
 
</syntaxhighlight>
 
  
c. Install the Prometheus Operator:
+
== Deployment Steps ==
<syntaxhighlight lang="bash">
 
helm install prometheus-operator prometheus-community/kube-prometheus-stack -n monitoring
 
</syntaxhighlight>
 
 
 
d. Verify the installation:
 
<syntaxhighlight lang="bash">
 
kubectl get pods -n monitoring
 
</syntaxhighlight>
 
 
 
=== Configure Values ===
 
Edit <code>values.yaml</code> to set your specific configuration:
 
 
 
<syntaxhighlight lang="yaml">
 
Deployment:
 
  name: <project-id>
 
  namespace: default
 
 
 
PersistentVolume:
 
  node: jiriaf2302-control-plane
 
  path: /var/prom
 
  size: 5Gi
 
 
 
Prometheus:
 
  serviceaccount: prometheus-k8s
 
  namespace: monitoring
 
</syntaxhighlight>
 
 
 
Key configurations:
 
* <code>Deployment.name</code>: Used for job naming, persistent volume path, and service monitoring selection
 
* <code>Deployment.namespace</code>: Specifies job namespace and namespace monitoring selection
 
* <code>PersistentVolume.*</code>: Configures storage for Prometheus data
 
* <code>Prometheus.*</code>: Sets Prometheus server details
 
 
 
Note: Only those <code>servicemonitors</code> with the namespace <code>default</code> can be monitored. To monitor additional namespaces, additional configuration is required. Refer to the [https://github.com/prometheus-operator/kube-prometheus/blob/main/docs/customizations/monitoring-additional-namespaces.md Prometheus Operator documentation on customizations] for details.
 
 
 
=== Install the Custom Prometheus Helm Chart ===
 
Run the following command, replacing <code>&lt;project-id&gt;</code> with your identifier:
 
  
<syntaxhighlight lang="bash">
+
# '''Install Prometheus Operator''': First, we need to install the Prometheus Operator:
helm install <project-id>-prom prom/ --set Deployment.name=<project-id>
+
## Create a namespace for monitoring:
</syntaxhighlight>
+
  <syntaxhighlight lang="bash">
 +
  kubectl create namespace monitoring
 +
  </syntaxhighlight>
 +
## Add the Prometheus Operator Helm repository:
 +
  <syntaxhighlight lang="bash">
 +
  helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
 +
  helm repo update
 +
  </syntaxhighlight>
 +
## Install the Prometheus Operator:
 +
  <syntaxhighlight lang="bash">
 +
  helm install prometheus-operator prometheus-community/kube-prometheus-stack -n monitoring
 +
  </syntaxhighlight>
 +
## Verify the installation:
 +
  <syntaxhighlight lang="bash">
 +
  kubectl get pods -n monitoring
 +
  </syntaxhighlight>
  
Example:
+
# '''Configure Values''': Edit `values.yaml` to set your specific configuration:
<syntaxhighlight lang="bash">
+
  <syntaxhighlight lang="yaml">
ID=jlab-100g-nersc-ornl
+
  Deployment:
helm install $ID-prom prom/ --set Deployment.name=$ID
+
    name: <project-id>
</syntaxhighlight>
+
    namespace: default
 +
 
 +
  PersistentVolume:
 +
    node: jiriaf2302-control-plane
 +
    path: /var/prom
 +
    size: 5Gi
 +
 
 +
  Prometheus:
 +
    serviceaccount: prometheus-k8s
 +
    namespace: monitoring
 +
  </syntaxhighlight>
 +
  Key configurations:
 +
  * `Deployment.name`: Used for job naming, persistent volume path, and service monitoring selection
 +
  * `Deployment.namespace`: Specifies job namespace and namespace monitoring selection
 +
  * `PersistentVolume.*`: Configures storage for Prometheus data
 +
  * `Prometheus.*`: Sets Prometheus server details
  
=== Verify Deployment ===
+
  Note: Only those `servicemonitors` with the namespace `default` can be monitored. To monitor additional namespaces, additional configuration is required. Refer to the [https://github.com/prometheus-operator/kube-prometheus/blob/main/docs/customizations/monitoring-additional-namespaces.md Prometheus Operator documentation on customizations] for details.
Check that all components are running:
 
<syntaxhighlight lang="bash">
 
kubectl get pods -n monitoring
 
kubectl get pv
 
</syntaxhighlight>
 
  
=== Access Grafana Dashboard ===
+
# '''Install the Custom Prometheus Helm Chart''': Run the following command, replacing `<project-id>` with your identifier:
a. Find the Grafana service:
+
  <syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
+
  helm install <project-id>-prom prom/ --set Deployment.name=<project-id>
kubectl get svc -n monitoring
+
  </syntaxhighlight>
</syntaxhighlight>
+
  Example:
 +
  <syntaxhighlight lang="bash">
 +
  ID=jlab-100g-nersc-ornl
 +
  helm install $ID-prom prom/ --set Deployment.name=$ID
 +
  </syntaxhighlight>
  
b. Set up port forwarding:
+
# '''Verify Deployment''': Check that all components are running:
<syntaxhighlight lang="bash">
+
  <syntaxhighlight lang="bash">
kubectl port-forward svc/prometheus-operator-grafana -n monitoring 3000:80
+
  kubectl get pods -n monitoring
</syntaxhighlight>
+
  kubectl get pv
 +
  </syntaxhighlight>
  
c. Access Grafana at <code>http://localhost:3000</code> (default credentials: admin/admin)
+
# '''Access Grafana Dashboard''':
 +
## Find the Grafana service:
 +
  <syntaxhighlight lang="bash">
 +
  kubectl get svc -n monitoring
 +
  </syntaxhighlight>
 +
## Set up port forwarding:
 +
  <syntaxhighlight lang="bash">
 +
  kubectl port-forward svc/prometheus-operator-grafana -n monitoring 3000:80
 +
  </syntaxhighlight>
 +
## Access Grafana at `http://localhost:3000` (default credentials: admin/admin)
  
 
== Components Deployed ==
 
== Components Deployed ==
  
* Prometheus Server (<code>prometheus.yaml</code>)
+
* Prometheus Server (`prometheus.yaml`)
* Persistent Volume for data storage (<code>prom-pv.yaml</code>)
+
* Persistent Volume for data storage (`prom-pv.yaml`)
* Empty directory creation job (<code>prom-create_emptydir.yaml</code>)
+
* Empty directory creation job (`prom-create_emptydir.yaml`)
  
 
== Integration with Workflows ==
 
== Integration with Workflows ==
Line 108: Line 102:
 
== Advanced Configuration ==
 
== Advanced Configuration ==
  
For further customization, refer to the Helm chart templates and <code>values.yaml</code>. Ensure your cluster has the necessary permissions and resources for persistent volumes and Prometheus server operation.
+
For further customization, refer to the Helm chart templates and `values.yaml`. Ensure your cluster has the necessary permissions and resources for persistent volumes and Prometheus server operation.
  
 
== Troubleshooting ==
 
== Troubleshooting ==
  
 
If you encounter issues:
 
If you encounter issues:
# Check pod status: <code>kubectl get pods -n monitoring</code>
+
# Check pod status: `kubectl get pods -n monitoring`
# View pod logs: <code>kubectl logs &lt;pod-name&gt; -n monitoring</code>
+
# View pod logs: `kubectl logs <pod-name> -n monitoring`
# Ensure persistent volume is correctly bound: <code>kubectl get pv</code>
+
# Ensure persistent volume is correctly bound: `kubectl get pv`
# Verify Prometheus configuration: <code>kubectl get prometheus -n monitoring -o yaml</code>
+
# Verify Prometheus configuration: `kubectl get prometheus -n monitoring -o yaml`
  
 
For more help, consult the [https://github.com/prometheus-operator/prometheus-operator/tree/main/Documentation Prometheus Operator documentation].
 
For more help, consult the [https://github.com/prometheus-operator/prometheus-operator/tree/main/Documentation Prometheus Operator documentation].

Revision as of 06:10, 16 September 2024

Deploy Prometheus Monitoring with Prometheus Operator

This guide outlines the deployment process for a custom Prometheus monitoring setup using the Prometheus Operator.

Prerequisites

Ensure your Kubernetes cluster has:

  1. Prometheus Operator
  2. Kubernetes Metrics Server
  3. Helm

Deployment Flow Chart

Below is a visual representation of the Prometheus deployment process:

Prometheus Deployment Flow Chart

This flow chart illustrates the key steps in deploying Prometheus monitoring using the Prometheus Operator.

Deployment Steps

  1. Install Prometheus Operator: First, we need to install the Prometheus Operator:
    1. Create a namespace for monitoring:
   kubectl create namespace monitoring
    1. Add the Prometheus Operator Helm repository:
   helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
   helm repo update
    1. Install the Prometheus Operator:
   helm install prometheus-operator prometheus-community/kube-prometheus-stack -n monitoring
    1. Verify the installation:
   kubectl get pods -n monitoring
  1. Configure Values: Edit `values.yaml` to set your specific configuration:
   Deployment:
     name: <project-id>
     namespace: default
   
   PersistentVolume:
     node: jiriaf2302-control-plane
     path: /var/prom
     size: 5Gi
   
   Prometheus:
     serviceaccount: prometheus-k8s
     namespace: monitoring
  Key configurations:
  * `Deployment.name`: Used for job naming, persistent volume path, and service monitoring selection
  * `Deployment.namespace`: Specifies job namespace and namespace monitoring selection
  * `PersistentVolume.*`: Configures storage for Prometheus data
  * `Prometheus.*`: Sets Prometheus server details
  Note: Only those `servicemonitors` with the namespace `default` can be monitored. To monitor additional namespaces, additional configuration is required. Refer to the Prometheus Operator documentation on customizations for details.
  1. Install the Custom Prometheus Helm Chart: Run the following command, replacing `<project-id>` with your identifier:
   helm install <project-id>-prom prom/ --set Deployment.name=<project-id>
  Example:
   ID=jlab-100g-nersc-ornl
   helm install $ID-prom prom/ --set Deployment.name=$ID
  1. Verify Deployment: Check that all components are running:
   kubectl get pods -n monitoring
   kubectl get pv
  1. Access Grafana Dashboard:
    1. Find the Grafana service:
   kubectl get svc -n monitoring
    1. Set up port forwarding:
   kubectl port-forward svc/prometheus-operator-grafana -n monitoring 3000:80
    1. Access Grafana at `http://localhost:3000` (default credentials: admin/admin)

Components Deployed

  • Prometheus Server (`prometheus.yaml`)
  • Persistent Volume for data storage (`prom-pv.yaml`)
  • Empty directory creation job (`prom-create_emptydir.yaml`)

Integration with Workflows

This setup is designed to monitor services and jobs created by your workflow system.

Advanced Configuration

For further customization, refer to the Helm chart templates and `values.yaml`. Ensure your cluster has the necessary permissions and resources for persistent volumes and Prometheus server operation.

Troubleshooting

If you encounter issues:

  1. Check pod status: `kubectl get pods -n monitoring`
  2. View pod logs: `kubectl logs <pod-name> -n monitoring`
  3. Ensure persistent volume is correctly bound: `kubectl get pv`
  4. Verify Prometheus configuration: `kubectl get prometheus -n monitoring -o yaml`

For more help, consult the Prometheus Operator documentation.