66 lines
3.2 KiB
Markdown
66 lines
3.2 KiB
Markdown
|
---
|
||
|
date: 2022-04-08
|
||
|
author: Alexandre LUCAZEAU
|
||
|
title: "Terraform + Proxmox"
|
||
|
slug:
|
||
|
draft: true
|
||
|
tags:
|
||
|
- proxmox
|
||
|
- terraform
|
||
|
- lxc
|
||
|
categories:
|
||
|
- virtualisation
|
||
|
description: "Utiliser Terraform pour provisionner VM et container dans Proxmox"
|
||
|
---
|
||
|
|
||
|
**Terraform** est un outil connu pour provisionner des machines, des instances etc.. dans des plateformes de cloud.
|
||
|
|
||
|
L'outil, modulable, peut-être utilisé avec votre serveur **Proxmox** et nous permettre d'avoir à la maison, une véritable infrastructure as code.
|
||
|
|
||
|
L'étape finale sera d'avoir des VM sous Nixos, pour avoir dans un dépôt git des environnement reproductibles à 100%.
|
||
|
|
||
|
**Terraform** va cloner une image ou un template, pour instancier une nouvelle machine virtuelle, ou un nouveau container, ayant des caractéristiques physiques décrites dans un fichier de configuration.
|
||
|
|
||
|
Il est donc nécessaire d'avoir intégrer cette image dans notre Proxmox. La machine virtuelle peut-être un template Proxmox, ou pas. On ainsi garder une VM éteinte qui servira de modèle, VM que l'on modifiera selon les besoins. Pratique pour se faire, par exemple, un template de VM LAMP.
|
||
|
Pour l'exemple ici, nous allons nous simplifier la vie en utilisant une image Cloud-Init Debian. La prochaine fois, on passera au template Nixos.
|
||
|
|
||
|
# Création du template dans Proxmox
|
||
|
|
||
|
Pour commencer il faut se connecter en SSH au serveur Proxmox et télécharger, via curl ou wget l'image CloudInit
|
||
|
|
||
|
A partir de cette image, on va créer un template :
|
||
|
|
||
|
qm create 9000 -name centos-8-stream-template -memory 1024 -net0 virtio,bridge=vmbr1 -cores 1 -sockets 1 -cpu cputype=kvm64 -description "Centos 8 Stream Cloud Image" -kvm 1 -numa 1
|
||
|
|
||
|
Ajouter le disque prédemment téléchargé à la VM et le stoker dans le dépôt (chez moi, il se nomme D1) :
|
||
|
|
||
|
qm importdisk 9000 CentOS-Stream-GenericCloud-8-20210210.0.x86_64.qcow2 D1
|
||
|
|
||
|
# On rattache le disque à la VM
|
||
|
qm set 9000 -scsihw virtio-scsi-pci -virtio0 local:9000/vm-9000-disk-0.raw
|
||
|
qm set 9000 -serial0 socket
|
||
|
# restreint le boot au disque cloud-init
|
||
|
qm set 9000 -boot c -bootdisk virtio0
|
||
|
qm set 9000 -agent 1
|
||
|
# activation du hotplug
|
||
|
qm set 9000 -hotplug disk,network,usb,memory,cpu
|
||
|
# 1 vcpu et 1 socket
|
||
|
qm set 9000 -vcpus 1
|
||
|
qm set 9000 -vga qxl
|
||
|
# nommage de la VM
|
||
|
qm set 9000 -name centos-8-stream-template
|
||
|
# Ajout du lecteur CD pour cloudinit
|
||
|
qm set 9000 -ide2 local:cloudinit
|
||
|
|
||
|
# Terraformer
|
||
|
|
||
|
Revenu sur notre poste de travail, nous allons voir comment terraformer des VM basées sur notre nouveau template
|
||
|
|
||
|
## Comment ça fonctionne
|
||
|
**Terraform** travail avec des fichiers locaux. Tous ceux présents dans le répertoire ou l'on se trouve. Cela signifie que les fichiers vont former un tout. On pourrait ainsi imaginer un répertoire par machine, ou par groupe de machines.
|
||
|
Bien sur, on assurera le suivi des fichiers via git.
|
||
|
|
||
|
**Proxmox** possède une API, et **Terraform** ou plutôt son module, est capable de l'utiliser. Nous allons donc créer un compte utilisateur, capable de se connecter, et d'utiliser un token pour l'authentification.
|
||
|
|
||
|
Les paramètres de connexions, et le module seront donc dans un fichier de configuration, les variables dans un autre, et le troisième fichier contiendra la description de notre infra, dans le language DSL de **Terraform**
|