try prometheus
This commit is contained in:
26
deploy/prometheus/ingress-alertmanager.yaml
Normal file
26
deploy/prometheus/ingress-alertmanager.yaml
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
# ingress-alertmanager.yaml
|
||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: alertmanager-ingress
|
||||||
|
namespace: monitoring
|
||||||
|
annotations:
|
||||||
|
cert-manager.io/cluster-issuer: "letsencrypt-prod"
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: /$2
|
||||||
|
spec:
|
||||||
|
ingressClassName: nginx
|
||||||
|
tls:
|
||||||
|
- hosts:
|
||||||
|
- alertmanager.prod.panic.haus
|
||||||
|
secretName: alertmanager-tls
|
||||||
|
rules:
|
||||||
|
- host: alertmanager.prod.panic.haus
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: alertmanager-main # service name for Alertmanager created by operator
|
||||||
|
port:
|
||||||
|
name: web # Alertmanager service port 9093 named "web"
|
||||||
26
deploy/prometheus/ingress-prometheus.yaml
Normal file
26
deploy/prometheus/ingress-prometheus.yaml
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: prometheus-ingress
|
||||||
|
namespace: monitoring
|
||||||
|
annotations:
|
||||||
|
cert-manager.io/cluster-issuer: "letsencrypt-prod"
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: /$2
|
||||||
|
nginx.ingress.kubernetes.io/proxy-buffer-size: "64k"
|
||||||
|
spec:
|
||||||
|
ingressClassName: nginx
|
||||||
|
tls:
|
||||||
|
- hosts:
|
||||||
|
- monitoring.prod.panic.haus
|
||||||
|
secretName: monitoring-tls
|
||||||
|
rules:
|
||||||
|
- host: monitoring.prod.panic.haus
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: prometheus-k8s # service name created by Prometheus operator for the Prom instance
|
||||||
|
port:
|
||||||
|
name: web # the Prometheus service uses port name "web" for 9090
|
||||||
18
deploy/prometheus/kustomization.yaml
Normal file
18
deploy/prometheus/kustomization.yaml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
|
||||||
|
resources:
|
||||||
|
# Include your own local manifests
|
||||||
|
- namespace.yaml
|
||||||
|
- ingress-prometheus.yaml
|
||||||
|
- ingress-alertmanager.yaml
|
||||||
|
# Reference the external repository’s manifests as a remote base:
|
||||||
|
- https://github.com/prometheus-operator/kube-prometheus.git//manifests?ref=main
|
||||||
|
|
||||||
|
patchesStrategicMerge:
|
||||||
|
# Any overlay patches to customize the external manifests, e.g., setting Longhorn as storage
|
||||||
|
- patch-prometheus.yaml
|
||||||
|
- patch-alertmanager.yaml
|
||||||
|
|
||||||
|
# Optionally set the namespace for the external resources
|
||||||
|
namespace: monitoring
|
||||||
7
deploy/prometheus/namespace.yaml
Normal file
7
deploy/prometheus/namespace.yaml
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
# namespace.yaml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: monitoring
|
||||||
|
labels:
|
||||||
|
name: monitoring
|
||||||
14
deploy/prometheus/patch-alertmanager.yaml
Normal file
14
deploy/prometheus/patch-alertmanager.yaml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
apiVersion: monitoring.coreos.com/v1
|
||||||
|
kind: Alertmanager
|
||||||
|
metadata:
|
||||||
|
name: main
|
||||||
|
spec:
|
||||||
|
replicas: 2
|
||||||
|
storage:
|
||||||
|
volumeClaimTemplate:
|
||||||
|
spec:
|
||||||
|
storageClassName: longhorn
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: 5Gi
|
||||||
|
externalUrl: "https://monitoring.prod.panic.haus"
|
||||||
14
deploy/prometheus/patch-prometheus.yaml
Normal file
14
deploy/prometheus/patch-prometheus.yaml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
apiVersion: monitoring.coreos.com/v1
|
||||||
|
kind: Prometheus
|
||||||
|
metadata:
|
||||||
|
name: k8s
|
||||||
|
spec:
|
||||||
|
replicas: 2
|
||||||
|
storage:
|
||||||
|
volumeClaimTemplate:
|
||||||
|
spec:
|
||||||
|
storageClassName: longhorn
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: 50Gi
|
||||||
|
externalUrl: "https://monitoring.prod.panic.haus"
|
||||||
12
deploy/prometheus/patch-rbac.yaml
Normal file
12
deploy/prometheus/patch-rbac.yaml
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: prometheus-operator
|
||||||
|
roleRef:
|
||||||
|
kind: ClusterRole
|
||||||
|
name: prometheus-operator
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: prometheus-operator
|
||||||
|
namespace: monitoring
|
||||||
39
deploy/prometheus/prometheus-operator.yaml
Normal file
39
deploy/prometheus/prometheus-operator.yaml
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
# prometheus-operator.yaml
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: prometheus-operator
|
||||||
|
namespace: monitoring
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: prometheus-operator
|
||||||
|
app.kubernetes.io/component: controller
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app.kubernetes.io/name: prometheus-operator
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: prometheus-operator
|
||||||
|
app.kubernetes.io/component: controller
|
||||||
|
spec:
|
||||||
|
serviceAccountName: prometheus-operator
|
||||||
|
containers:
|
||||||
|
- name: operator
|
||||||
|
image: quay.io/prometheus-operator/prometheus-operator:v0.66.0 # Example version
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
args:
|
||||||
|
- --address=0.0.0.0
|
||||||
|
- --kubelet-service=kube-system/kubelet # adjust if needed for your environment
|
||||||
|
- --manage-crds=false # assume CRDs applied via GitOps beforehand
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: 8080
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
cpu: 100m
|
||||||
|
memory: 100Mi
|
||||||
|
# Node affinity not required; operator can run on any node with correct arch
|
||||||
|
nodeSelector:
|
||||||
|
kubernetes.io/os: linux # ensure it's a Linux node
|
||||||
Reference in New Issue
Block a user