infrastructure/prometheus-deployment.yaml

222 lines
5.3 KiB
YAML

apiVersion: v1
kind: Namespace
metadata:
name: sysadmin
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: prometheus
rules:
- apiGroups: [""]
resources:
- nodes
- nodes/metrics
- nodes/proxy
- services
- endpoints
- pods
verbs: ["get", "list", "watch"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: prometheus
subjects:
- kind: ServiceAccount
name: default
namespace: sysadmin
roleRef:
kind: ClusterRole
name: prometheus
apiGroup: rbac.authorization.k8s.io
---
apiVersion: v1
kind: ConfigMap
metadata:
name: prometheus-configmap
namespace: sysadmin
data:
prometheus.yml: |
global:
scrape_interval: 60s
scrape_configs:
- job_name: "node_exporter"
static_configs:
- targets: ["144.76.186.182:9100"]
- job_name: "postgres_exporter"
static_configs:
- targets: ["postgres-exporter.databases:9187"]
- job_name: "clickhouse_exporter"
static_configs:
- targets: ["clickhouse.databases:9363"]
- job_name: "nats_exporter"
static_configs:
- targets: ["nats-exporter.databases:7777"]
- job_name: "kube_exporter"
static_configs:
- targets: ["kube-state-metrics.kube-system.svc.cluster.local:8080"]
- job_name: "kubernetes-cadvisor"
scheme: https
kubernetes_sd_configs:
- role: node
tls_config:
insecure_skip_verify: true
bearer_token_file: /var/run/secrets/kubernetes.io/serviceaccount/token
relabel_configs:
- action: labelmap
regex: __meta_kubernetes_node_label_(.+)
- target_label: __address__
replacement: kubernetes.default.svc:443
- source_labels: [__meta_kubernetes_node_name]
regex: (.+)
target_label: __metrics_path__
replacement: /api/v1/nodes/${1}/proxy/metrics/cadvisor
- job_name: "kubelet"
scheme: https
kubernetes_sd_configs:
- role: node
tls_config:
insecure_skip_verify: true
bearer_token_file: /var/run/secrets/kubernetes.io/serviceaccount/token
relabel_configs:
- action: labelmap
regex: __meta_kubernetes_node_label_(.+)
- target_label: __address__
replacement: kubernetes.default.svc:443
- source_labels: [__meta_kubernetes_node_name]
regex: (.+)
target_label: __metrics_path__
replacement: /api/v1/nodes/${1}/proxy/metrics
- job_name: "longhorn_exporter"
static_configs:
- targets: ["longhorn-backend.longhorn-system:9500"]
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: prometheus-pvc
namespace: sysadmin
spec:
accessModes:
- ReadWriteOnce
storageClassName: longhorn
resources:
requests:
storage: 10Gi
limits:
storage: 10Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: prometheus
namespace: sysadmin
spec:
replicas: 1
selector:
matchLabels:
ms: prometheus
template:
metadata:
labels:
ms: prometheus
spec:
containers:
- name: prometheus
image: prom/prometheus
args:
- --config.file=/etc/prometheus/prometheus.yml
- --storage.tsdb.retention.size=8GB
volumeMounts:
- name: data
mountPath: /prometheus/
- name: config
mountPath: /etc/prometheus/
securityContext:
runAsUser: 1000
fsGroup: 2000
volumes:
- name: data
persistentVolumeClaim:
claimName: prometheus-pvc
- name: config
configMap:
name: prometheus-configmap
---
apiVersion: v1
kind: Service
metadata:
name: prometheus
namespace: sysadmin
spec:
type: NodePort
selector:
ms: prometheus
ports:
- port: 9090
targetPort: 9090
---
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
namespace: sysadmin
name: letsencrypt-prod
spec:
acme:
server: https://acme-v02.api.letsencrypt.org/directory
email: florian@nocodelytics.com
privateKeySecretRef:
name: letsencrypt-prod
solvers:
- http01:
ingress:
class: traefik
---
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
namespace: sysadmin
name: prometheus
spec:
secretName: prometheus-net-tls
issuerRef:
name: letsencrypt-prod
kind: Issuer
commonName: prometheus.nocodelytics.com
dnsNames:
- prometheus.nocodelytics.com
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
namespace: sysadmin
name: prometheus-nginx-ingress
annotations:
traefik.ingress.kubernetes.io/router.middlewares: default-https-redirect@kubernetescrd,default-http-auth@kubernetescrd
spec:
rules:
- host: prometheus.nocodelytics.com
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: ssl-redirect
port:
name: use-annotation
- path: /
pathType: Prefix
backend:
service:
name: prometheus
port:
number: 9090
tls:
- hosts:
- prometheus.nocodelytics.com
secretName: prometheus-net-tls