blob: 4e866a97577fe252f51cf28faa847d60f69b7d1c [file] [log] [blame]
# Copyright (c) 2022 VEXXHOST, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
- name: Retrieve "etcd" CA certificate
ansible.builtin.slurp:
src: /etc/kubernetes/pki/etcd/ca.crt
register: _etcd_ca_crt
- name: Retrieve "etcd" client certificate
ansible.builtin.slurp:
src: /etc/kubernetes/pki/etcd/healthcheck-client.crt
register: _etcd_healthcheck_client_crt
- name: Retrieve "etcd" client key
ansible.builtin.slurp:
src: /etc/kubernetes/pki/etcd/healthcheck-client.key
register: _etcd_healthcheck_client_key
- name: Create namespace
kubernetes.core.k8s:
state: present
definition:
apiVersion: v1
kind: Namespace
metadata:
name: monitoring
- name: Create Secret with "etcd" TLS certificates
kubernetes.core.k8s:
state: present
definition:
apiVersion: v1
kind: Secret
metadata:
name: kube-prometheus-stack-etcd-client-cert
namespace: monitoring
data:
ca.crt: "{{ _etcd_ca_crt.content }}"
healthcheck-client.crt: "{{ _etcd_healthcheck_client_crt.content }}"
healthcheck-client.key: "{{ _etcd_healthcheck_client_key.content }}"
- name: Create CRDs for Prometheus Operator
kubernetes.core.k8s:
state: present
definition: "{{ lookup('ansible.builtin.url', 'https://raw.githubusercontent.com/prometheus-operator/prometheus-operator/v0.57.0/example/prometheus-operator-crd/monitoring.coreos.com_' ~ item ~ '.yaml', split_lines=false) | regex_replace('- =$', '- \"=\"', multiline=True) | from_yaml_all }}" # yamllint disable-line rule:line-length
apply: true
server_side_apply:
field_manager: Atmosphere
force_conflicts: true
loop:
- alertmanagerconfigs
- alertmanagers
- podmonitors
- probes
- prometheuses
- prometheusrules
- servicemonitors
- thanosrulers
# NOTE(mnaser): We replace `- =` with `- "="` to avoid a YAML error, this also
# breaks idempotency so we flip to `changed_when: false`.
# See: https://github.com/yaml/pyyaml/issues/619
changed_when: false
- name: Deploy Helm chart
kubernetes.core.helm:
name: kube-prometheus-stack
chart_ref: prometheus-community/kube-prometheus-stack
chart_version: 36.2.0
release_namespace: monitoring
kubeconfig: /etc/kubernetes/admin.conf
values: "{{ _kube_prometheus_stack_values | combine(kube_prometheus_stack_values, recursive=True) }}"
wait: true