docs/content/configuration/clusters.md
2023-05-23 21:29:28 +02:00

2.3 KiB

Title Description Weight
Clusters Un cluster est un groupe d'hosts pouvant être de type différent mais travaillant ensemble dans un même environnement. 20

Les Clusters représentent les différents clusters Kubernetes d'une organisation. Ils sont la plupart du temps nommés selon un environnement bien défini, par exemple prod, qual, dev, etc... et permettent la séparation facile des application qui y sont déployées. Il est néanmoins possible de nommer librement ses clusters selon ses objectifs et ses contraintes, comme par exemple selon le nom d'une équipe de développement, d'une large application, etc...

Les information des clusters sont stockés dans le dossier clusters, dans des fichiers yaml séparés selon les noms définis ci-dessus. Ces fichiers peuvent présenter un large nombre de variables permettant d'exprimer les différences entre tous les clusters gérés par la configuration globale. Ces variables vont s'appliquer à tous les [Hosts]({{< relref "configuration/hosts" >}}) déclarés comme faisant partie des-dits clusters, et à l'inverse, il n'est évidemment pas possible d'allouer un host à plusieurs clusters en même temps.

{{< highlight yaml >}} domain: cluster.local

subnets: services: 192.168.48.0/20 pods: 192.168.64.0/20

addons:

  • essentials

vars: kubernetes_version: v1.26.4

bootstrap_auths:

  • name: "my-user" sshKey: "ssh-ed25519 xxx my-user"

ssh_keys:

  • "ssh-ed25519 xxx my-user"

devname_match: /dev/([shv]da|nmve[0-9]+n[0-9]+)

to match a specific partition (here: 3):

#devname_match: /dev/([shv]da|nvme[0-9]+n[0-9]+p)3

vip_interface: main public_vip: 10.42.0.10

netmask: 24 gateway: 10.42.0.254 dns:

  • 10.42.0.1

dls_base_url: http://10.42.0.254:7606

etcd: image: quay.io/coreos/etcd version: v3.5.9 cluster_state: new # set to existing to secure existing clusters

keepalived: image: novitnc/keepalived version: 2.0.19 garp_master_refresh: 60 router_id: 1

control_plane: api_port: 6443 reserve_resources: true

iface: "(en|eth).*" containerd_size: 50%FREE

local_storage_class: local

encrypt_disks: false

cni_provider: knet-wg ingress_controller: nginx kube_proxy: proxy

k8s_registry: registry.k8s.io

kernel_modules: []

{{< / highlight >}}