Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

90 Minutes Avec OpenStack

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 93

90 minutes avec OpenStack

Laurent Foucher
email: u03@u03.fr
blog: h ps://blog.u03.fr/
git : h ps://github.com/U03
Version : 2019/11/11

90 Minutes avec OpenStack – 2019/11/11 1


A propos de ce livre
J’ai écrit ce livre comme une introduc on à OpenStack en français, car il est important pour moi de
disposer de ressources en français, même s’il faut bien l’adme re la « langue officielle » de
l’informa que est l’anglais.

Il est probable qu’il vous faille plus de 90 minutes pour lire ce livre, en par culier si vous reproduisez
les différents exemples, réalisez les quelques exercices et surtout expérimentez par vous même.

Ce livre vous est offert sous la licence ‘Crea ve Commons’ :

« A ribu on - Pas d’U lisa on Commerciale - Partage dans les Mêmes Condi ons 3.0 France »

Vous trouverez plus d’informa ons sur ce e licence sur le site de ‘Crea ve Commons France’ :

h ps://crea vecommons.org/licenses/by-nc-sa/3.0/fr/

90 Minutes avec OpenStack – 2019/11/11 2


Table des matières
Présenta on de OpenStack......................................................................................................................6

Architecture de OpenStack.......................................................................................................................6

Installa on de DevStack............................................................................................................................8

Premier contact avec OpenStack............................................................................................................11

Les projets et les u lisateurs........................................................................................................11

L’API et l’interface en ligne de commande...................................................................................11

Les images.....................................................................................................................................12

Les volumes..................................................................................................................................12

Les clés SSH...................................................................................................................................13

Les quotas et les gabarits.............................................................................................................14

Les réseaux...................................................................................................................................15

Connexion au Dashboard........................................................................................................................16

Notre première instance.........................................................................................................................18

A savoir avant de lancer notre première instance........................................................................18

Lancement de notre première instance.......................................................................................18

Associa on d’une adresse IP flo ante.........................................................................................23

Modifica on du groupe de sécurité.............................................................................................25

Connexion à l’instance..................................................................................................................30

Affichage des informa ons sur l’instance....................................................................................30

Suppression des éléments créés..................................................................................................32

U lisa on des images.............................................................................................................................32

Téléchargement de l’image Ubuntu « Cloud Image »..................................................................32

Contrôle de l’intégrité de l’image téléchargée.............................................................................33

Chargement de l’image dans Glance............................................................................................33

Vérifica on de la disponibilité de l’image....................................................................................34

Lancement d’une instance en ligne de commandes..............................................................................34

Créa on d’un groupe de sécurité.................................................................................................35

Lancement de l’instance...............................................................................................................36

90 Minutes avec OpenStack – 2019/11/11 3


Ajout d’une adresse IP flo ante à notre instance........................................................................38

Connexion à notre instance..........................................................................................................39

Les volumes de données.........................................................................................................................40

Créa on d’un volume de données via le Dashboard...................................................................40

Prépara on (par onnement et formatage) du volume.............................................................43

Détachement du volume via le Dashboard..................................................................................44

Suppression d’un volume via le Dashboard.................................................................................44

Créa on et a achement d’un volume en ligne de commande....................................................45

Détachement et suppression d’un volume en ligne de commande.............................................46

L’orchestra on.........................................................................................................................................47

L’orchestra on avec Heat........................................................................................................................47

Les ressources...............................................................................................................................47

Une première pile...................................................................................................................................49

U lisa on de la pile......................................................................................................................50

Suppression de la pile...................................................................................................................54

Autres types de ressources de Heat.......................................................................................................55

Créa on d’une groupe de sécurité et d’une adresse IP flo ante................................................55

U lisa on d’une adresse IP flo ante...........................................................................................56

Créa on d’un volume à par r d’une image..................................................................................57

A achement d’un volume de données à une instance................................................................57

U lisa on des piles à l’aide du CLI openstack........................................................................................59

Lancement d’une pile...................................................................................................................59

Mise à jour d’une pile...................................................................................................................60

Destruc on d’une pile..................................................................................................................61

Lancement d’une pile avec un fichier de paramètres..................................................................61

Créa on d’infrastructures réseau...........................................................................................................63

Créa on des réseaux et sous-réseaux..........................................................................................65

A achement du serveur au réseau..............................................................................................67

A achement à plusieurs réseaux.................................................................................................67

Le stockage d’objets avec Swi ...............................................................................................................69

90 Minutes avec OpenStack – 2019/11/11 4


Créa on d’un conteneur Swi et chargement d’objets depuis le Dashboard.............................69

Manipula on des conteneurs et objets en ligne de commande..................................................71

Stockage et récupéra on d’un fichier..........................................................................................72

Ajout de propriétés.......................................................................................................................72

Terraform................................................................................................................................................74

Installa on et ini alisa on...........................................................................................................74

Éléments d’une configura on......................................................................................................75

Une première configura on.........................................................................................................76

Créa on d’un volume système et d’un groupe de sécurité :.......................................................78

Créa on et u lisa on de réseaux.................................................................................................80

Script d’ini alisa on d’instance simple........................................................................................81

Script d’ini alisa on d’instance complexe (template).................................................................82

U lisa on directe des API.......................................................................................................................83

Obten on d’un Token et de la liste des endpoints.......................................................................83

U lisa on de l’API Cinder : Obtenir la liste des volumes..............................................................85

U lisa on de l’API Cinder : Créa on d’un volume........................................................................87

U lisa on de l’API Compute: Créa on d’une instance.................................................................89

U lisa on du client CLI openstack en mode debug.....................................................................91

Conclusion...............................................................................................................................................93

90 Minutes avec OpenStack – 2019/11/11 5


Présenta on de OpenStack
OpenStack est un ensemble de logiciels qui perme ent de déployer des infrastructures virtuelles
(Infrastructure As A Service).

Chaque infrastructure (projet ou tenant) est composée de serveurs virtuels (instances ou serveurs)
qui fournissent la puissance de traitement, u lisent du stockage (disques virtuels, fichiers) et
s’intègrent dans des réseaux virtuels (sous-réseaux, routeurs, pare-feu).

Les projets sont indépendants les uns des autres, les adresses IP à l’intérieur d’un projet sont privées,
elles sont choisies librement par l’administrateur du projet, elles ne sont accessibles ni de l’extérieur,
ni des autres projets.

L’administrateur du système OpenStack définit des adresses IP spécifiques qui sont routables depuis
l’extérieur du Cloud, ces adresses sont appelées ‘adresses IP flo antes’. Les administrateurs des
différents projets peuvent demander que des adresses leur soient allouées pour rendre accessibles
des instances depuis l’extérieur de leur projet.

L’administra on et l’u lisa on de OpenStack se fait à travers d’une collec on d’API (Applica on
Programming Interface) qui donnent à OpenStack sa puissance et sa souplesse. Ces API sont
u lisables grâce à une Interface en Ligne de Commande (CLI), grâce à une interface web spécifique
appelée Dashboard, ou grâce à tout programme ou script capable d’appeler les API directement.

Architecture de OpenStack
Il y a 4 groupes de services :

• Control

• Network

• Storage

• Compute

L’élément Control fait fonc onner les API, l’interface web, la base de données (MySQL, MariaDB ou
PostgreSQL), et le bus de messages (RabbitMQ, Qpid ou Ac veMQ).

Les principaux éléments cons tuant OpenStack sont les suivants :

• Dashboard : L’interface web, elle u lise l’API d’OpenStack, elle est développée sur le
framework ‘Horizon’ (ce qui lui vaut d’être parfois appelée ‘Horizon’)

• Keystone : Composant de ges on des iden tés, il gère l’authen fica on mais également il
assure la par e catalogue : pour les points d’accès (endpoints) aux autres API, les projets,
u lisateurs, rôles et tous les composants. Keystone est la pierre angulaire du système, tous
les composants doivent appartenir à un projet (également appelé tenant ou propriétaire)

• Nova : gère les instances (serveurs virtuels)

90 Minutes avec OpenStack – 2019/11/11 6


• Glance : gère les images qui perme ent de lancer les instances, il s’agit d’images de disques
avec l’OS préinstallé et non d’images de DVD d’installa on. Ces images sont rendues
anonymes (suppression des adresses MAC, clés SSH…) la personnalisa on est faite par le
script ‘cloud-init’ lors du boot de l’instance

• Neutron : Ges on du réseau virtuel (SDN : So ware Defined Network)

• Cinder : Ges onnaire de stockage en mode blocs, il permet de créer des volumes (des
disques durs virtuels) qui seront u lisables par les instances

• Swi : Ges onnaire de stockage d’objets, il permet de stocker des objets (fichiers) qui seront
accessibles via une URL, avec ou sans authen fica on

• Ceilometer : Métrologie

• Heat : Orchestra on (automa sa on du déploiement des architectures).

L’orchestra on est un point important dans les infrastructures Cloud, elle permet de déployer des
infrastructures de façon automa que, mais surtout de les redéployer autant de fois que nécessaire,
en par culier pour réaliser la mise en produc on des applica ons.

La CI/CD (Intégra on Con nue / Déploiement Con nu) est une méthode et un ensemble d’ou ls qui
perme ent à par r d’un référen el (de programmes, de paramètres) d’automa ser la créa on
(intégra on) d’artefacts (paquetages livrables), puis d’automa ser le déploiement de ces artefacts
vers différents environnements (intégra on, qualifica on, rece e, pré-produc on, produc on).

L’orchestra on et la CI/CD associées aux technologies du Cloud rendent les infrastructures


« jetables » puisque facilement déployables, que ce soient les serveurs, les logiciels installés, le
paramétrage du système d’exploita on et des logiciels associés, et même l’applica on.

Ainsi seules données sont conservées de façon perenne.

90 Minutes avec OpenStack – 2019/11/11 7


Installa on de DevStack
DevStack est une distribu on simplifiée d’OpenStack qui fait fonc onner les éléments nécessaires à
un environnement de développement sur un serveur unique.

La distribu on DevStack déploie les éléments principaux d’OpenStack, elle est des née à la forma on
et au développement, elle est déconseillée en produc on.

Il est conseillé d’avoir au moins 16Go de RAM disponibles sur la machine cible.

Nous commençons par préparer le serveur physique en installant le système d’exploita on « Ubuntu
Server 18.04.3 LTS » (ou la dernière version LTS disponible sur le site de Ubuntu):

• h ps://www.ubuntu.com/download/server

LTS signifie Long Term Support afin de différencier les versions de produc on qui sont supportées
durant 5 ans minimum, des versions dites de développement qui servent à me re au point la release
LTS suivante.

Les versions de développement con ennent des versions plus récentes des produits par rapport aux
versions LTS mais elles ne disposent d’aucun support et ne sont pas nécessairement stables.

Une installa on par défaut de Ubuntu est suffisante, ne pas oublier d’ajouter l’op on ‘SSH Server’
afin de pouvoir accéder à votre serveur en SSH. La procédure d’installa on de Ubuntu vous propose
de créer un compte u lisateur, créez un compte nommé ‘stack’ avec le mot de passe de votre choix
(ce compte aura droit d’u liser la commande ‘sudo’ en spécifiant son mot de passe),

L’installa on de DevStack est simple, elle ne nécessite que l’installa on du client Git, les autres
packages nécessaires seront installés automa quement. Un fichier de configura on minimal permet
de procéder au déploiement de DevStack.

Nous réalisons les étapes suivantes :

• Modifica on du fichier sudoers pour autoriser l’u lisateur stack à passer des
commandes à la place de root sans avoir à spécifier de mot de passe.

• Mise à jour de l’index des packages de apt, puis installa on du package git

• Clone du repository Git de DevStack

• Créa on du fichier de configura on perme ant l’installa on de DevStack. Modifiez le


paramètre HOST_IP pour me re l’adresse IP du serveur sur lequel vous procédez à
l’installa on. Tous les mots de passe auront pour valeur ‘topsecret’.

• Le paramètre VOLUME_BACKING_FILE_SIZE permet de spécifier l’espace disque qui


sera alloué à Cinder pour stocker les différents volumes. L’alloca on est faite en mode ‘thin
provisionning’, l’espace u lisé sur le disque physique dépend de l’u lisa on réelle qui est
faite par Cinder.

• Installa on de DevStack grâce à la commande ‘./stack.sh’ (la commande


‘./unstack.sh’ perme ra de procéder à la désinstalla on si nécessaire).
stack@microwave:~$ echo "stack ALL=(ALL) NOPASSWD: ALL" | sudo tee -a /etc/sudoers

90 Minutes avec OpenStack – 2019/11/11 8


stack@microwave:~$ sudo apt-get update
stack@microwave:~$ sudo apt-get -y install git

stack@microwave:~$ git clone https://git.openstack.org/openstack-dev/devstack

stack@microwave:~$ cd devstack
stack@microwave:~/devstack$ cat << EOF > local.conf
[[local|localrc]]
HOST_IP=192.168.1.211
GIT_BASE=http://git.openstack.org
ADMIN_PASSWORD=topsecret
DATABASE_PASSWORD=\$ADMIN_PASSWORD
RABBIT_PASSWORD=\$ADMIN_PASSWORD
SERVICE_PASSWORD=\$ADMIN_PASSWORD
#
# Activation de Swift sans replication
#
enable_service s-proxy s-object s-container s-account
SWIFT_HASH=66a3d6b56c1f479c8b4e70ab5c2000f5
SWIFT_REPLICAS=1
SWIFT_DATA_DIR=$DEST/data/swift
#
# Activation du composant HEAT et de l’onglet HEAT dans le dashboard
#
enable_plugin heat https://git.openstack.org/openstack/heat
enable_plugin heat-dashboard https://git.openstack.org/openstack/heat-dashboard
#
# Agrandissement volume pour Cinder
#
VOLUME_BACKING_FILE_SIZE=100G
EOF

stack@microwave:~/devstack$ ./stack.sh
[…/…]
=========================
DevStack Component Timing
(times are in seconds)
=========================
run_process 53
test_with_retry 4
apt-get-update 2
osc 359
wait_for_service 26
git_timed 1100
dbsync 107
pip_install 982
apt-get 736
-------------------------
Unaccounted time 848
=========================
Total runtime 4217

This is your host IP address: 192.168.1.211


This is your host IPv6 address: ::1
Horizon is now available at http://192.168.1.211/dashboard
Keystone is serving at http://192.168.1.211/identity/
The default users are: admin and demo
The password: topsecret

L’installa on de DevStack dure jusqu’à 1 heure en fonc on de la puissance de votre serveur mais
aussi de la vitesse de votre connexion à Internet pour télécharger les éléments nécessaires.

Une fois DevStack installée vous pouvez autoriser vos futures machines virtuelles à se connecter à
Internet (et à votre réseau privé) en paramétrant le NAT comme ceci :
stack@microwave:~$ ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 94:18:82:38:17:30 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.211/24 brd 192.168.1.255 scope global dynamic eno1
valid_lft 73654sec preferred_lft 73654sec
inet6 fe80::9618:82ff:fe38:1730/64 scope link
valid_lft forever preferred_lft forever
stack@microwave:~$ sudo iptables -t nat -A POSTROUTING -o eno1 -j MASQUERADE

Il arrive que le réseau privé créé défaut créé par DevStack ne comporte pas de DNS, vous pouvez
u liser ceux de Google, ou de votre réseau privé comme ceci :

90 Minutes avec OpenStack – 2019/11/11 9


stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack subnet set private-subnet --dns-nameserver 8.8.8.8 --dns-nameserver 8.8.4.4

90 Minutes avec OpenStack – 2019/11/11 10


Premier contact avec OpenStack
Les projets et les u lisateurs
Toutes les ressources doivent appartenir à un projet, un u lisateur ne peut u liser les ressources d’un
projet que si un rôle lui a été a ribué sur ce projet.

Certaines ressources ne sont pas liées à un projet, mais à un u lisateur, c’est le cas par exemple des
clés SSH que nous verrons un peu plus loin.

L’API et l’interface en ligne de commande


Les différents composants de OpenStack déploient des API (Applica on Programing Interface) avec
lesquelles il est possible de communiquer en u lisant le protocole TCP via des points d’entrée
(endpoint) catalogués dans KeyStone.

Un u litaire en ligne de commande (CLI – Command Line Interface) est fourni pour s’interfacer avec
les composants OpenStack de façon simple. Il est également téléchargeable séparément pour pouvoir
gérer son infrastructure depuis une machine distante.

Ces API sont également u lisables par des u litaires d’automa sa on (orchestra on) qui perme ent
de déployer des infrastructures à la demande de façon reproduc ble.

On l’a dit, Keystone est le point d’entrée du système, il gère l’authen fica on ainsi que le catalogue
des différents projets (tenants) et endpoints.

Pour interagir avec OpenStack il faut disposer du endpoint de KeyStone, d’un nom d’u lisateur, d’un
mot de passe et du nom d’un projet sur lequel on souhaite travailler (ou du nom du projet d’admin).

Après authen fica on KeyStone va fournir un jeton d’authen fica on (token), ainsi que la liste des
endpoints des autres API parmi lesquels on peut choisir le endpoint nécessaire (par exemple Glance
pour la ges on des images…) Ce jeton permet ensuite de s’authen fier auprès des autres services, un
jeton a une durée de vie limitée qui est donnée par KeyStone en même temps que la valeur du jeton.

Le client CLI de OpenStack est appelé ‘openstack’, il u lise des variables d’environnement ou des
paramètres en ligne de commande pour se connecter à l’infrastructure OpenStack. Ce e commande
permet de passer des commandes à tous les composants de OpenStack.

DevStack est fourni avec script appelé ‘openrc’ qui posi onne les variables nécessaires, il prend 2
paramètres faculta fs, le premier est le nom d’u lisateur (‘demo’ par défaut), le second est le nom
du projet (‘demo’ par défaut).

Ci-dessous nous appelons le script openrc pour nous placer avec le user demo dans le projet demo,
dans les variables posi onnées par le script on note l’URL d’accès KeyStone qui est le point d’entrée
du système :
stack@microwave:~$ cd ~/devstack
stack@microwave:~/devstack$ source openrc demo demo
stack@microwave:~/devstack$ set | grep -P "^OS_"
OS_AUTH_TYPE=password
OS_AUTH_URL=http://192.168.1.211/identity
OS_CACERT=
OS_IDENTITY_API_VERSION=3

90 Minutes avec OpenStack – 2019/11/11 11


OS_PASSWORD=topsecret
OS_PROJECT_DOMAIN_ID=default
OS_PROJECT_NAME=demo
OS_REGION_NAME=RegionOne
OS_TENANT_NAME=demo
OS_USERNAME=demo
OS_USER_DOMAIN_ID=default
OS_VOLUME_API_VERSION=2

La syntaxe générale de la commande ‘openstack’ est :

openstack objet opération paramètres :

Maintenant que les variables d’environnement nécessaires sont posi onnées nous pouvons appeler
l’u litaire ‘openstack’ pour avoir la liste des projets sur lesquels l’u lisateur a des droits :
stack@microwave:~$ openstack project list
+----------------------------------+--------------------+
| ID | Name |
+----------------------------------+--------------------+
| 8eb8bd6dcd2447b2bc8224b4ceb64672 | demo |
| 8feed042b5504d3fa074fca9ae4694f5 | invisible_to_admin |
+----------------------------------+--------------------+

Les images
L’installa on d’un serveur physique est réalisée en installant le système d’exploita on sur un volume
(disque dur) en démarrant le serveur sur un DVD d’installa on.

La créa on d’une instance (serveur virtuel) se fait en u lisant une image spécifique préparée à par r
d’un disque sur lequel un système d’exploita on a été installé.

Les éditeurs de systèmes d’exploita on fournissent ces images ‘Cloud Ready’ au même tre que les
images de média d’installa on.

Les images ‘Cloud Ready’ sont anonymisées (suppression des adresses MAC des cartes réseau, des
clés SSH) et un script spécifique appelé ‘cloud-init’ est installé dessus, il prendra en charge le
paramétrage des instances lors de leur démarrage.

Les volumes
Les volumes sont des disques durs virtuels (on parle de stockage en mode ‘blocs’), ils sont créés par
exemple lors de la créa on d’une instance pour y placer le système d’exploita on présent sur l’image
u lisée.

Dans le Cloud l’infrastructure est virtuelle, habituellement elle est également éphémère car détruite
et redéployée par l’Orchestra on à chaque fois que cela est nécessaire (par exemple pour installer
une mise à jour de l’applica on ou du système d’exploita on).

C’est pourquoi on déploie le système d’exploita on sur un volume qui ne con endra aucune donnée,
il sera détruit et recréé à chaque mise en produc on en même temps que l’instance qui l’u lisait.

On crée séparément des volumes sur lesquels on va stocker les données de façon pérenne, lors des
mises en produc on ces volumes seront détachés des instances auxquelles ils étaient connectés, ils
seront ensuite reconnectés aux instances créées par l’Orchestra on lors du déploiement de la mise
en produc on.

90 Minutes avec OpenStack – 2019/11/11 12


Les clés SSH
L’u lisa on de mots de passe pour se connecter à un serveur n’est pas sécurisée, lors de la créa on
d’une instance on spécifie une clé publique qui sera ajoutée par cloud-init aux clés autorisées de
l’u lisateur par défaut pour perme re la connexion en SSH à l’instance.

Le nom de l’u lisateur par défaut est le nom de la distribu on (centos pour CentOS, debian pour
Debian et ubuntu pour Ubuntu)

Il existe deux possibilités concernant les clés SSH :

• U liser un bi-clé existant, et ajouter la clé publique dans la base de données de OpenStack

• Faire rer un bi-clé par la commande OpenStack, la clé publique sera automa quement
ajoutée dans la base de donnés de OpenStack, la clé privée associée devra être conservée
pour être u lisée lors de la connexion à l’instance

Les clés SSH de type DSA ne sont pas u lisables avec OpenStack, en effet ce type de clés est
reconnu comme non sûr. Pour pouvoir u liser une clé existante elle doit être
obligatoirement de type RSA.

U lisa on d’une clé existante


La commande openstack keypair create avec le paramètre --public-key permet
d’ajouter une clé publique SSH sans la base de données OpenStack.

La clé appar ent à u lisateur, elle n’appar ent pas à un projet en par culier, elle est u lisable pour
tous les projets de l’u lisateur. Les autres u lisateurs qui ont accès aux mêmes projets que vous n’ont
pas accès à vos clés.
stack@microwave:~$ cd devstack/
stack@microwave:~/devstack$ source openrc demo
stack@microwave:~/devstack$ openstack keypair create --public-key ~/.ssh/id_rsa.pub "Foucher Laurent RSA"
+-------------+-------------------------------------------------+
| Field | Value |
+-------------+-------------------------------------------------+
| fingerprint | 71:1d:81:03:3c:46:97:b8:e8:88:eb:e2:b2:15:6c:f5 |
| name | Foucher Laurent RSA |
| user_id | 7436b216d6ee4a1b809c723579c0e2bc |
+-------------+-------------------------------------------------+
stack@microwave:~/devstack$ openstack user show 7436b216d6ee4a1b809c723579c0e2bc
+---------------------+----------------------------------+
| Field | Value |
+---------------------+----------------------------------+
| domain_id | default |
| email | demo@example.com |
| enabled | True |
| id | 7436b216d6ee4a1b809c723579c0e2bc |
| name | demo |
| options | {} |
| password_expires_at | None |
+---------------------+----------------------------------+

Pour informa on un bi-clé SSH de type RSA s’ob ent comme ceci :
stack@microwave:~$ ssh-keygen -t rsa -b 4096 -C "Ma cle SSH"
Generating public/private rsa key pair.
Enter file in which to save the key (/home/stack/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/stack/.ssh/id_rsa.
Your public key has been saved in /home/stack/.ssh/id_rsa.pub.
The key fingerprint is:

90 Minutes avec OpenStack – 2019/11/11 13


SHA256:MvDIiOz6TPR+ACWZn5DT1vfyLLBGtMyog54UPX3I118 Ma cle SSH
The key's randomart image is:
+---[RSA 4096]----+
| = . |
| B + o . |
| .B+*.o.. |
|.o.=+B*o... E |
|.o+o+.*oS+. . |
|ooo.. oo. o. |
|o.o..o . |
|.= . . |
|..o .. |
+----[SHA256]-----+

Créa on d’un bi-clé par la commande OpenStack


La commande openstack keypair create avec le paramètre --private-key permet de
rer un bi-clé et d’ajouter la clé publique SSH dans la base de données OpenStack. La clé privée est
sauvegardée dans le fichier spécifié en paramètre, il faut faire très a en on en manipulant ce fichier,
il est à traiter avec la même prudence qu’un mot de passe en clair. En par culier a en on aux droits
sur le fichier qui sont ceux par défaut de l’u lisateur (umask) et sont trop permissifs :
stack@microwave:~/devstack$ openstack keypair create --private-key ~/cle_privee "Cle Generee par OpenStack"
+-------------+-------------------------------------------------+
| Field | Value |
+-------------+-------------------------------------------------+
| fingerprint | ea:b3:47:9a:de:0d:a4:61:37:e3:1e:6a:5d:ce:ba:bd |
| name | Cle Generee par OpenStack |
| user_id | 7436b216d6ee4a1b809c723579c0e2bc |
+-------------+-------------------------------------------------+
stack@microwave:~/devstack$ ls -l ~/cle_privee
-rw-rw-r-- 1 stack stack 1675 Feb 11 22:19 /home/stack/cle_privee
stack@microwave:~/devstack$ chmod 600 ~/cle_privee
-rw------- 1 stack stack 1675 Feb 11 22:19 /home/stack/cle_privee

Les quotas et les gabarits


A chaque projet sont associés des quotas qui définissent la quan té maximale de chaque type de
ressources qui peuvent être allouées par le projet :

• Instances: le nombre de serveurs virtuels

• vCPU : le nombre de processeurs virtuels

• RAM : la mémoire vive totale qui peut être allouée aux différentes instances

• Adresses IP flo antes (adresses IP accessibles depuis l’extérieur du projet

• Groupes de sécurité : les pare-feu placés en frontal des instances pour filtrer les flux entrants
et sortants des instances

• Volumes : les disques durs virtuels qui perme ent de stocker le système d’exploita on ou les
données des instances (en nombre et en taille totale)

Les administrateurs des projets peuvent commander des instances de serveurs virtuels parmi
différents modèles (vCPU, RAM…) appelés gabarits (ou flavor en anglais dans le dashboard et le CLI).
Seul l’administrateur OpenStack peut définir ces gabarits.
stack@microwave:~$ openstack flavor list
+----+-----------+-------+------+-----------+-------+-----------+
| ID | Name | RAM | Disk | Ephemeral | VCPUs | Is Public |
+----+-----------+-------+------+-----------+-------+-----------+
| 1 | m1.tiny | 512 | 1 | 0 | 1 | True |
| 2 | m1.small | 2048 | 20 | 0 | 1 | True |
| 3 | m1.medium | 4096 | 40 | 0 | 2 | True |
| 4 | m1.large | 8192 | 80 | 0 | 4 | True |
| 42 | m1.nano | 64 | 0 | 0 | 1 | True |
| 5 | m1.xlarge | 16384 | 160 | 0 | 8 | True |

90 Minutes avec OpenStack – 2019/11/11 14


| 84 | m1.micro | 128 | 0 | 0 | 1 | True |
| c1 | cirros256 | 256 | 0 | 0 | 1 | True |
| d1 | ds512M | 512 | 5 | 0 | 1 | True |
| d2 | ds1G | 1024 | 10 | 0 | 1 | True |
| d3 | ds2G | 2048 | 10 | 0 | 2 | True |
| d4 | ds4G | 4096 | 20 | 0 | 4 | True |
+----+-----------+-------+------+-----------+-------+-----------+

Les réseaux
OpenStack permet de construire des infrastructures complètes, y compris au niveau réseau.

En créant des routeurs et des réseaux on crée des infrastructures qui se rapprochent des
infrastructures ‘legacy’ (héritées).

Les réseaux correspondent à des réseaux physiques, un réseau est composé d’au moins un sous-
réseau.

Les sous-réseaux dans Neutron correspondent à des sous-réseaux au niveau IP, leur défini on est
composée des éléments suivants :

• La plage d’adresse, elle est définie en nota on CIDR : adresse de réseau + longueur de
masque (par exemple : 192.168.1.0/24)

• Une plage d’adresse DHCP perme ant d’a ribuer dynamiquement des adresses aux instances

• La passerelle par défaut du sous-réseau

• Les DNS qui seront u lisés par les serveurs

Des routeurs perme ent d’interconnecter les réseaux entre eux.

Des ports, qui correspondent à des prises réseaux (carte réseau de serveur, port de routeur…)

Nous verrons comment construire des réseaux dans la par e consacrée à l’orchestra on Heat.

90 Minutes avec OpenStack – 2019/11/11 15


Connexion au Dashboard
On pourrait traduire ‘Dashboard’ par ‘Tableau de bord’, il est également appelé ‘Horizon’. Il s’agit de
l’interface graphique de OpenStack.

Le Dashboard est u lisable avec n’importe quel navigateur moderne. Par défaut lors de l’installa on
de DevStack les u lisateurs ‘demo’ et ‘admin’ sont créés avec le mot de passe choisi lors de
l’installa on (il est rappelé à la fin de l’installa on de DevStack en même temps que l’URL d’accès au
Dashboard).

Lors de la connexion au Dashboard un premier écran s’affiche avec les différents quotas dont nous
avons parlé. A gauche du bandeau supérieur une liste déroulante permet de passer d’un projet à
l’autre parmi les différents projets sur lesquels nous avons des droits. A droite est rappelé quel
u lisateur est connecté, un menu déroulant permet de modifier certains réglages (en par culier la
langue d’affichage du Dashboard et le fuseau horaire).

90 Minutes avec OpenStack – 2019/11/11 16


Nous u lisons l’op on «Paramètres»du menu déroulant de droite pour change la langue de
l’interface et nous placer dans le fuseau horaire de notre choix. Il est possible de se placer en « UTC »
(Temps Universel) ou « UTC+1 : France ».

Souvent les serveurs sont réglés sur le fuseau horaire UTC, pour des raisons de commodité dans les
grandes infrastructures Cloud qui s’étalent sur plusieurs fuseaux horaires, dans ce cas choisir UTC
dans le Dashboard permet de rester cohérent avec l’heure des serveurs.

90 Minutes avec OpenStack – 2019/11/11 17


Notre première instance
A savoir avant de lancer notre première instance
Nous allons lancer notre première instance grâce au Dashboard, mais auparavant nous allons discuter
d’un point essen el sur les volumes et sur l’infrastructure d’OpenStack.

Nous avons dit qu’OpenStack est (entre autres) composé de nœuds (serveurs) de type « Compute »
(ce sont ceux sur lesquels s’exécutent nos instances) et de nœuds de type « Storage » (ce sont ceux
qui ont en charge le stockage des volumes de données).

Il possible de lancer une instance en laissant OpenStack créer un volume pour le système
d’exploita on directement sur l’espace de stockage du nœud « compute ». Cependant en cas de
panne du nœud (ou si l’administrateur décide de l’arrêter pour une mise à jour par exemple) alors
l’instance et les données présentes sur ce volume sont perdues…

La bonne façon de faire est de créer un volume à par r de l’image du système d’exploita on que nous
souhaitons u liser, ce volume sera u lisé pour lancer notre instance.

Pour nos premiers tests nous allons u liser une image de système d’exploita on spécifiquement faite
pour les tests, elle est légère, ne nécessite pas beaucoup de ressources, n’a pas de nombreuses
fonc onnalités et ne doit pas être u lisée en produc on pour des raisons de sécurité. Son nom est
‘Cirros’, elle a été téléchargée depuis Internet et ajoutée à OpenStack par la procédure d’installa on
de DevStack.

Lancement de notre première instance


Dans le Dashboard nous affichons l’onglet « Projet → Compute → Images », ici nous voyons l’image
de Cirros. A droite de l’image ‘cirros’ nous avons un menu déroulant et nous choisissons « Créer le
volume »

Nous appelons notre volume « premier_volume », la source est déjà renseignée puisque nous
appelons ce e fonc on depuis l’écran « Images », nous laissons la taille à 1Go (c’est largement

90 Minutes avec OpenStack – 2019/11/11 18


suffisant pour Cirros), les paramètres « Type » et « Zone de disponibilité » doivent être laissés à leur
valeur par défaut, cliquons sur « Créer le volume ».

Nous affichons l’onglet « Projet → Volumes → Volumes », nous voyons le volume que nous venons de
créer, il fait 1Go, son statut est « disponible » cela signifie qu’il n’est a aché à aucune instance, il est
« amorçable » car il a été créé à par r d’une image de système d’exploita on, ça veux dire qu’on peut
s’en servir pour lancer une instance.

Nous allons pouvoir créer l’instance en nous servant de ce volume, nous allons dans l’onglet « Projet
→ Compute → Instances » et nous cliquons sur « Lancer une instance » :

90 Minutes avec OpenStack – 2019/11/11 19


L’écran de lancement d’une instance s’affiche, il est cons tué de plusieurs onglets, les onglets qui
doivent être remplis sont suivis d’une étoile « * », le bouton « Lancer l’Instance » reste en grisé tant
que tous les onglets requis ne sont pas complétés.

Nous entrons « premiere_instance » dans le champ « Nom de l’instance » et nous cliquons sur
l’onglet « Source » :

Dans le champ « Sélec onner le source de démarrage » nous choisissons « Volume », dans la zone
inférieure de l’onglet la liste des volumes amorçables disponibles s’affiche, nous cliquons sur la flèche
à droite du volume « premier_volume » :

90 Minutes avec OpenStack – 2019/11/11 20


Le volume « premier_volume » passe de la zone « Disponibles » à « Alloué », on clique sur l’onglet
« Gabarit » :

La liste des gabarits s’affiche, on sélec onne le gabarit « m1. ny » qui est le plus pe t gabarit avec
1vCPU et 512Mo de mémoire :

90 Minutes avec OpenStack – 2019/11/11 21


Il faut choisir dans l’onglet ‘Réseaux’ à quel réseau a acher notre instance, nous choisissons
‘private’ :

Si on clique sur l’onglet « Paire de clés » on voit que comme une seule clé est disponible elle a été
sélec onnée par défaut (c’est aussi le cas d’autres éléments sur d’autres onglets). Il est déjà possible
de lancer l’instance, nous la lançons en cliquant sur ‘Lancer Instance’ :

90 Minutes avec OpenStack – 2019/11/11 22


L’instance que nous venons de créer apparaît dans l’onglet « Projet → Compute → Instances »,
l’instance a une adresse IP qui lui a été allouée, ce e adresse IP est une adresse IP privée, elle n’est
pas accessible depuis l’extérieur de notre projet OpenStack.

Associa on d’une adresse IP flo ante


Le Cloud OpenStack dispose d’un certain nombre d’adresses IP flo antes, l’administrateur d’un projet
peut demander à se faire allouer des adresses IP flo antes (dans la limite des quotas du projet),
quand une adresse IP flo ante est allouée au projet l’administrateur peut l’associer à une instance.

Nous allons a ribuer une adresse IP flo ante à l’instance afin qu’elle soit accessible en dehors de
notre projet. Nous choisissons « Allouer une adresse IP flo ante » dans le menu déroulant en face de
notre instance :

90 Minutes avec OpenStack – 2019/11/11 23


Pour le moment nous n’avons pas d’IP flo ante allouée à notre projet. Nous commençons par
demander l’alloca on d’une IP flo ante en cliquant sur le « + » en face de « Aucune IP flo ante
allouée » :

Nous demandons l’alloca on d’une adresse IP dans le réseau « public » et nous cliquons sur
« Alloca on d’IP » :

Une adresse IP flo ante nous est allouée, nous pouvons maintenant l’associer à notre instance en
cliquant sur « Associer » :

90 Minutes avec OpenStack – 2019/11/11 24


L’adresse IP flo ante qui a été associée apparaît maintenant en face de notre instance :

Si après avoir dissocié une adresse IP flo ante d’une instance vous la libérez elle sera
rendue au pool créé par les administrateurs du système et il n’y a aucun moyen de vous la
réa ribuer.

Ceci peut être un problème si jamais vous avez référencé ce e adresse à l’extérieur (DNS,
Firewall, applica ons erces..)

Modifica on du groupe de sécurité


Les groupes de sécurité sont des pare-feu qui se placent devant les instances pour filtrer les flux
réseau entrants et sortants. Le pare-feu par défaut autorise tous les flux sortants de l’instance, et
bloque tous les flux entrants.

L’administrateur du projet peut créer des groupes de sécurité en fonc on de ses besoins (dans la
limite des quotas de son projet)

Nous allons modifier le groupe de sécurité par défaut afin d’autoriser les connexions SSH (protocole
TCP port 22) vers notre instance.

Les groupes de sécurité sont dans l’onglet « Projet → Réseau → Groupes de sécurité », pour le
moment nous n’avons que le groupe « default » qu’il ne faut surtout pas modifier :

90 Minutes avec OpenStack – 2019/11/11 25


Nous allons créer un nouveau groupe de sécurité en cliquant sur ‘Créer un groupe de sécurité’, nous
l’appelons ‘ssh_externe’ et nous validons la créa on en cliquant sur le bouton en bas à droite :

Suite à la créa on du groupe de sécurité nous arrivons directement sur l’écran de ges on des règles :

90 Minutes avec OpenStack – 2019/11/11 26


En cliquant sur « Ajouter une règle » nous allons ajouter la règle dont nous avons besoin pour
autoriser les connexions SSH, nous créons une « Règle TCP personnalisée , en « Entrée», pour le
« Port » numéro « 22 » (SSH), quelle que soit l’origine « CIDR 0.0.0.0/0) :

90 Minutes avec OpenStack – 2019/11/11 27


Une fois la modifica on validée les différentes règles qui composent le groupe de sécurité s’affichent :

Il faut désormais a ribuer le groupe de sécurité que nous venons de créer à notre instance afin que
vous puissions nous connecter. Ceci se fait depuis l’écran « Projet → Compute → Instances », en
cliquant sur ‘éditer les groupes de sécurité’ dans le menu déroulant en face de notre instance :

90 Minutes avec OpenStack – 2019/11/11 28


Les groupes de sécurité disponibles mais non associés à l’instance apparaissent dans la colonne de
gauche, ceux associés à l’instance dans la colonne de droite. Cliquer sur le ‘+’ ou le ‘-’ en face d’un
groupe le fait passer d’une colonne à l’autre :

Nous associons le groupe ‘ssh_externe’ à l’instance et nous enregistrons:

90 Minutes avec OpenStack – 2019/11/11 29


Connexion à l’instance
Nous pouvons désormais nous connecter en SSH à notre instance depuis notre serveur DevStack en
u lisant l’adresse IP flo ante de notre instance et le user « cirros », l’adresse IP flo ante est affichée
en face de l’instance dans le Dashboard :
stack@microwave:~$ ssh cirros@172.24.4.38
The authenticity of host '172.24.4.38 (172.24.4.38)' can't be established.
ECDSA key fingerprint is SHA256:Lq/GLmCuTBJrUqJ7GpB/q8sz6VqGfrqQbZ0kIzSpp3o.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.24.4.38' (ECDSA) to the list of known hosts.
$ uname -a
Linux premiere-instance 4.4.0-28-generic #47-Ubuntu SMP Fri Jun 24 10:09:13 UTC 2016 x86_64 GNU/Linux

Comme nous avons lancé instance en spécifiant notre clé SSH nous avons pu nous connecter sans
avoir à spécifier de mot de passe. Si nous avons un problème avec notre clé SSH nous pouvons u liser
le mot passe « cubswin:) » ou « gocubsgo » (à par r de cirros v0.4)

Notez que le nom de notre instance est ‘premiere_instance’ et que le hostname de


l’instance est ‘premiere-instance’ car le caractère ‘_’ est interdit dans les entrées DNS
(et donc dans les hostnames)

Affichage des informa ons sur l’instance


Depuis la liste des instances dans le Dashboard (projet → compute → instances) nous pouvons
afficher les informa ons sur une instance, sa log système ainsi que sa console (écran / clavier).

En cliquant sur le nom du serveur, nous affichons 4 onglets (Vue d’ensemble, Journal, Console, Log
des ac ons) :

90 Minutes avec OpenStack – 2019/11/11 30


L’onglet « Journal » donne la log système de l’instance (sur écran cliquer ‘Voir le journal complet’
permet d’afficher le journal complet et pas seulement les 35 dernières lignes) :

L’onglet « Console » permet d’avoir l’écran et le clavier de l’instance :

90 Minutes avec OpenStack – 2019/11/11 31


Il peut être nécessaire de cliquer sur ‘Cliquer ici pour ne voir que la console’ afin que la
console soit u lisable.

La disposi on des touches du clavier peut ne pas être correcte (AZERTY/QWERTY)

Suppression des éléments créés


Depuis le Dashboard nous pouvons supprimer les éléments crées :

• L’instance depuis le menu « Projet → Compute → Instances » en cliquant sur le menu


déroulant à droite de l’instance concernée et en sélec onnant « Supprimer l’instance ».

• Le volume associé de la même façon depuis le menu « Projet → Volumes → Volumes »

• Le groupe de sécurité depuis l’écran « Réseau → Groupes de sécurité »

• L’adresse IP flo ante depuis l’écran « Réseau → IP flo antes »,choisir « Libérer l’IP flo ante »
dans le menu déroulant à droite de l’adresse

U lisa on des images


Les éditeurs de systèmes d’exploita on fournissent des images « cloud ready », contrairement aux
images classiques qui sont des images de DVD d’installa on de l’OS les images « Cloud Ready » sont
des images de disques sur lesquels l’OS a été installé.

Téléchargement de l’image Ubuntu « Cloud Image »


Nous allons télécharger l’image cloud de Ubuntu 18.04, les images cloud de Ubuntu 16.04 sont
disponibles à l’adresse suivante:
https://cloud-images.ubuntu.com/releases/18.04/release/

90 Minutes avec OpenStack – 2019/11/11 32


Il y a deux points auxquels il faut faire a en on :

• Tout comme pour les serveurs réels, les images cloud sont dépendantes du processeur, nous
allons prendre une image ‘amd64’ qui correspond aux architectures Intel/AMD en 64 bits

• Ensuite le format de l’image dépend de l’hyperviseur (le système de cloud) u lisé : HyperV
(Microso Azure), OVF (VMware), QCOW2 (QEMU et KVM). DevStack est basé sur
l’hyperviseur KVM, nous prenons donc l’image QCOW2

Nous allons prendre le fichier ubuntu-18.04-server-cloudimg-amd64.img (le libellé


‘Cloud image for 64-bit computers (USB image)’ pour ce e image prête à confusion)
stack@microwave:~$ wget https://cloud-images.ubuntu.com/releases/bionic/release/ubuntu-18.04-server-cloudimg-amd64.img
--2019-10-13 20:31:01-- https://cloud-images.ubuntu.com/releases/bionic/release/ubuntu-18.04-server-cloudimg-amd64.img
Resolving cloud-images.ubuntu.com (cloud-images.ubuntu.com)... 91.189.88.89, 2001:67c:1560:8001::8001
Connecting to cloud-images.ubuntu.com (cloud-images.ubuntu.com)|91.189.88.89|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 344588288 (329M) [application/octet-stream]
Saving to: ‘ubuntu-18.04-server-cloudimg-amd64.img’

ubuntu-18.04-server-cloudimg-amd64.img 100%
[============================================================================>] 328.62M 827KB/s in 6m 49s > ] 312.99M
2019-10-13 20:37:50 (823 KB/s) - ‘ubuntu-18.04-server-cloudimg-amd64.img’ saved [344588288/344588288]

Contrôle de l’intégrité de l’image téléchargée


Une fois l’image téléchargée nous contrôlons la somme de contrôle du fichier téléchargé (les sommes
de contrôle sont dans des fichiers SHA512SUMS et MD5SUMS sur la page de téléchargement).

Plusieurs algorithmes de hashage sont u lisés, nous pouvons u liser sha512sum pour contrôler
l’intégrité du fichier téléchargé, MD5 n’est plus considéré comme un algorithme sûr, mais c’est celui
u lisé par Glance pour le contrôle d’intégrité (on retrouve ce e somme de contrôle dans le champ
checksum des commandes openstack image).
stack@microwave:~$ sha512sum ubuntu-18.04-server-cloudimg-amd64.img
e39393b4b347790b18c…4c0fc4be4cbcf084c56d ubuntu-18.04-server-cloudimg-amd64.img

stack@microwave:~$ md5sum ubuntu-18.04-server-cloudimg-amd64.img


33e7b1e0d309877a3f6c27bc52d1bd68 ubuntu-18.04-server-cloudimg-amd64.img

Chargement de l’image dans Glance


Nous chargeons l’image dans Glance qui est en charge du catalogage et du stockage des images dans
OpenStack.

Tout u lisateur d’un projet peut charger une image dans Glance, elle ne sera visible que dans son
projet (ce comportement est modifiable par l’administrateur).

L’administrateur du système OpenStack (ou un u lisateur disposant des droits nécessaires) peut
charger une image dans Glance et la rendre publique c’est à dire visible depuis tous les projets.

Nous chargeons les variables d’environnement nécessaires pour nous authen fier comme user
admin dans le projet admin et nous chargeons l’image dans Glance en la rendant publique :
stack@microwave:~$ source devstack/openrc admin admin
stack@microwave:~$ openstack image create --public \
--disk-format qcow2 \
--container-format bare \
--file ubuntu-18.04-server-cloudimg-amd64.img \
ubuntu-18.04

+------------------+---------------------------------------------------------------------------------------------------+
| Field | Value |

90 Minutes avec OpenStack – 2019/11/11 33


+------------------+---------------------------------------------------------------------------------------------------+
| checksum | 33e7b1e0d309877a3f6c27bc52d1bd68 |
| container_format | bare |
| created_at | 2019-10-13T20:48:03Z |
| disk_format | qcow2 |
| file | /v2/images/7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5/file |
| id | 7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5 |
| min_disk | 0 |
| min_ram | 0 |
| name | ubuntu-18.04 |
| owner | 0302dd0df6e74588a279d139e452b219 |
| properties | os_hash_algo='sha512', os_hash_value='e39393b4b347790b18c…4c0fc4be4cbcf084c56d', os_hidden='False'|
| protected | False |
| schema | /v2/schemas/image |
| size | 344588288 |
| status | active |
| tags | |
| updated_at | 2019-10-13T20:48:11Z |
| virtual_size | None |
| visibility | public |
+------------------+---------------------------------------------------------------------------------------------------+

stack@microwave:~$ openstack image list


+--------------------------------------+--------------------------+--------+
| ID | Name | Status |
+--------------------------------------+--------------------------+--------+
| 67d1e1b2-a9f8-451f-afd2-f4697da2b6c7 | cirros-0.4.0-x86_64-disk | active |
| 7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5 | ubuntu-18.04 | active |
+--------------------------------------+--------------------------+--------+

Certaines images sont compressées (en .zip ou .xz) il faut les décompresser avant de les
charger dans Glance.

D’une manière générale Glance ne fait aucun contrôle sur l’image : charger une image avec
les mauvais paramètres, charger une image compressée ou d’un format incorrect produira
des erreurs ina endues au moment du lancement d’une instance u lisant ce e image.

Vérifica on de la disponibilité de l’image


Nous vérifions que l’image est disponible dans le projet demo, on note que l’u lisateur demo n’a pas
les autorisa ons nécessaires pour supprimer ce e image car il s’agit d’une image publique :
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack image list
+--------------------------------------+--------------------------+--------+
| ID | Name | Status |
+--------------------------------------+--------------------------+--------+
| 67d1e1b2-a9f8-451f-afd2-f4697da2b6c7 | cirros-0.4.0-x86_64-disk | active |
| 7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5 | ubuntu-18.04 | active |
+--------------------------------------+--------------------------+--------+
stack@microwave:~$ openstack image delete ubuntu-18.04
Failed to delete image with name or ID 'ubuntu-18.04': HTTP 403 Forbidden: You are not permitted to delete this image.
Failed to delete 1 of 1 images.

Lancement d’une instance en ligne de commandes


Nous pouvons lancer une instance grâce à la commande openstack de la même manière que nous
l’avons fait en u lisant précédemment en u lisant le Dashboard.

Nous commençons par créer le volume système que nous allons appeler ubuntu-18.04_vol à
par r de l’image ubuntu-18.04, ce e opéra on peut prendre une ou plusieurs minutes, et
l’image passe par plusieurs états avant d’être disponible.
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack image list
+--------------------------------------+--------------------------+--------+
| ID | Name | Status |
+--------------------------------------+--------------------------+--------+
| 67d1e1b2-a9f8-451f-afd2-f4697da2b6c7 | cirros-0.4.0-x86_64-disk | active |

90 Minutes avec OpenStack – 2019/11/11 34


| 7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5 | ubuntu-18.04 | active |
+--------------------------------------+--------------------------+--------+
stack@microwave:~$ openstack volume create --size 10 --image ubuntu-18.04 ubuntu-18.04_vol
+---------------------+--------------------------------------+
| Field | Value |
+---------------------+--------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | false |
| consistencygroup_id | None |
| created_at | 2019-10-13T21:02:45.000000 |
| description | None |
| encrypted | False |
| id | edc26441-2f67-410d-8b24-a1e85844d8dc |
| multiattach | False |
| name | ubuntu-18.04_vol |
| properties | |
| replication_status | None |
| size | 10 |
| snapshot_id | None |
| source_volid | None |
| status | creating |
| type | lvmdriver-1 |
| updated_at | None |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
+---------------------+--------------------------------------+
stack@microwave:~$ openstack volume show ubuntu-18.04_vol
+------------------------------+--------------------------------------+
| Field | Value |
+------------------------------+--------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | false |
| consistencygroup_id | None |
| created_at | 2019-10-13T21:02:45.000000 |
| description | None |
| encrypted | False |
| id | edc26441-2f67-410d-8b24-a1e85844d8dc |
| multiattach | False |
| name | ubuntu-18.04_vol |
| os-vol-tenant-attr:tenant_id | 5cd4212611654857a9e941a7b5d35e13 |
| properties | |
| replication_status | None |
| size | 3 |
| snapshot_id | None |
| source_volid | None |
| status | downloading |
| type | lvmdriver-1 |
| updated_at | 2019-10-13T21:03:21.000000 |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
| volume_image_metadata | {u'signature_verified': u'False'} |
+------------------------------+--------------------------------------+
stack@microwave:~$ openstack volume show ubuntu-18.04_vol
+------------------------------+-----------------------------------------------------------------------+
| Field | Value |
+------------------------------+-----------------------------------------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | true |
| consistencygroup_id | None |
| created_at | 2019-10-13T21:02:45.000000 |
| description | None |
| encrypted | False |
| id | edc26441-2f67-410d-8b24-a1e85844d8dc |
| multiattach | False |
| name | ubuntu-18.04_vol |
| os-vol-tenant-attr:tenant_id | 5cd4212611654857a9e941a7b5d35e13 |
| properties | |
| replication_status | None |
| size | 10 |
| snapshot_id | None |
| source_volid | None |
| status | available |
| type | lvmdriver-1 |
| updated_at | 2019-10-13T21:04:42.000000 |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
| volume_image_metadata | {u'checksum': u'33e7b1e0d309877a3f6c27bc52d1bd68', u'min_ram': u'0', |
| | u'disk_format': u'qcow2', u'image_name': u'ubuntu-18.04', |
| | u'image_id': u'7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5', | |
| | u'signature_verified': u'False', u'container_format': u'bare', |
| | u'min_disk': u'0', u'size': u'344588288'} |
+------------------------------+-----------------------------------------------------------------------+

Créa on d’un groupe de sécurité


Nous allons créer notre propre « security group » qui autorise tout le trafic en sor e (c’est le
comportement par défaut) et autorise le port 22 (SSH) en entrée.

90 Minutes avec OpenStack – 2019/11/11 35


stack@microwave:~$ openstack security group create bastion_ssh
+-----------------+-----------------------------------------+
| Field | Value |
+-----------------+-----------------------------------------+
| created_at | 2019-10-13T21:12:20Z |
| description | bastion_ssh |
| id | 9116395f-92dc-47c8-bd38-9424f6b7f88f |
| name | bastion_ssh |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| revision_number | 1 |
| rules | direction='egress', ethertype='IPv6' |
| | direction='egress', ethertype='IPv4' |
| tags | [] |
| updated_at | 2019-10-13T21:12:20Z |
+-----------------+-----------------------------------------+
stack@microwave:~$ openstack security group rule create --ingress --remote-ip 0.0.0.0/0 \
--protocol tcp --dst-port 22 bastion_ssh
+-------------------+------------------------------------------+
| Field | Value |
+-------------------+------------------------------------------+
| created_at | 2019-10-13T21:12:34Z |
| description | |
| direction | ingress |
| ether_type | IPv4 |
| id | 08a8650e-1b28-4f8e-beb7-2c21bbff7b99 |
| name | None |
| port_range_max | 22 |
| port_range_min | 22 |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| protocol | tcp |
| remote_group_id | None |
| remote_ip_prefix | 0.0.0.0/0 |
| revision_number | 0 |
| security_group_id | 9116395f-92dc-47c8-bd38-9424f6b7f88f |
| tags | [] |
| updated_at | 2019-10-13T21:12:34Z |
+-------------------+------------------------------------------+
stack@microwave:~$ openstack security group show bastion_ssh
+-----------------+--------------------------------------------------------------+
| Field | Value |
+-----------------+--------------------------------------------------------------+
| created_at | 2019-10-13T21:12:20Z |
| description | bastion_ssh |
| id | 9116395f-92dc-47c8-bd38-9424f6b7f88f |
| name | bastion_ssh |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| revision_number | 2 |
| rules | direction='ingress', ethertype='IPv4', |
| | port_range_max='22', port_range_min='22', protocol='tcp', |
| | remote_ip_prefix='0.0.0.0/0' |
| | direction='egress', ethertype='IPv6' |
| | direction='egress', ethertype='IPv4' |
| tags | [] |
| updated_at | 2019-10-13T21:12:34Z |
+-----------------+--------------------------------------------------------------+

Lancement de l’instance
Pour lancer notre instance nous avons besoin des éléments suivantes :

• Le volume système que nous venons de créer

• Un gabarit (flavor), par exemple m1.small

• Une clé publique pour pouvoir nous connecter en SSH à l’instance, elle est déjà disponible

• Le groupe de sécurité qui autorise tout le trafic en sor e et le port 22 en entrée

• Le réseau privé auquel a acher l’instance


stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+-----------+------+-------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+-----------+------+-------------+
| edc26441-2f67-410d-8b24-a1e85844d8dc | ubuntu-18.04_vol | available | 10 | |
+--------------------------------------+------------------+-----------+------+-------------+
stack@microwave:~$ openstack security group list
+--------------------------------------+-------------+------------------------+----------------------------------+------+
| ID | Name | Description | Project | Tags |
+--------------------------------------+-------------+------------------------+----------------------------------+------+
| 4545dc36-f071-43c5-b902-a7b6fe35b586 | default | Default security group | 5cd4212611654857a9e941a7b5d35e13 | [] |
| 9116395f-92dc-47c8-bd38-9424f6b7f88f | bastion_ssh | bastion_ssh | 5cd4212611654857a9e941a7b5d35e13 | [] |
+--------------------------------------+-------------+------------------------+----------------------------------+------+

90 Minutes avec OpenStack – 2019/11/11 36


stack@microwave:~$ openstack flavor list
+----+-----------+-------+------+-----------+-------+-----------+
| ID | Name | RAM | Disk | Ephemeral | VCPUs | Is Public |
+----+-----------+-------+------+-----------+-------+-----------+
| 1 | m1.tiny | 512 | 1 | 0 | 1 | True |
| 2 | m1.small | 2048 | 20 | 0 | 1 | True |
| 3 | m1.medium | 4096 | 40 | 0 | 2 | True |
| 4 | m1.large | 8192 | 80 | 0 | 4 | True |
| 42 | m1.nano | 64 | 1 | 0 | 1 | True |
| 5 | m1.xlarge | 16384 | 160 | 0 | 8 | True |
| 84 | m1.micro | 128 | 1 | 0 | 1 | True |
| c1 | cirros256 | 256 | 1 | 0 | 1 | True |
| d1 | ds512M | 512 | 5 | 0 | 1 | True |
| d2 | ds1G | 1024 | 10 | 0 | 1 | True |
| d3 | ds2G | 2048 | 10 | 0 | 2 | True |
| d4 | ds4G | 4096 | 20 | 0 | 4 | True |
+----+-----------+-------+------+-----------+-------+-----------+
stack@microwave:~$ openstack keypair list
+------+-------------------------------------------------+
| Name | Fingerprint |
+------+-------------------------------------------------+
| LFO | 8c:56:76:56:d9:de:50:81:8b:4d:6c:b1:ee:55:b2:ae |
+------+-------------------------------------------------+
stack@microwave:~$ openstack network list
+--------------------------------------+---------+--------------------------------------+
| ID | Name | Subnets |
+--------------------------------------+---------+--------------------------------------+
| 0e6e2f0c-c4cc-4eca-8428-8117864b6e4a | private | 10b8dba4-4613-4462-b8f4-500bd6c7fc84 |
| 12ceb0b7-9ed6-4bfd-9160-ab44b4f868b2 | public | b3ee49a7-80b9-4898-8f53-a58cb1e3908c |
| 38f2e146-43e0-4f93-b3db-87fc25a4be19 | shared | 29ea72f8-7ac3-4d2a-a2f8-e4b2f2946718 |
+--------------------------------------+---------+--------------------------------------+
stack@microwave:~$ openstack server create --volume ubuntu-18.04_vol \
--security-group bastion_ssh \
--flavor m1.small \
--key-name "LFO" \
--network private \
ubuntu-18.04_inst
+-----------------------------+---------------------------------------------+
| Field | Value |
+-----------------------------+---------------------------------------------+
| OS-DCF:diskConfig | MANUAL |
| OS-EXT-AZ:availability_zone | |
| OS-EXT-STS:power_state | NOSTATE |
| OS-EXT-STS:task_state | scheduling |
| OS-EXT-STS:vm_state | building |
| OS-SRV-USG:launched_at | None |
| OS-SRV-USG:terminated_at | None |
| accessIPv4 | |
| accessIPv6 | |
| addresses | |
| adminPass | YdPdfs86o22C |
| config_drive | |
| created | 2019-10-13T21:23:44Z |
| flavor | m1.small (2) |
| hostId | |
| id | 01e719a0-abd4-44dd-99e1-27076de3dce5 |
| image | |
| key_name | LFO |
| name | ubuntu-18.04_inst |
| progress | 0 |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| properties | |
| security_groups | name='9116395f-92dc-47c8-bd38-9424f6b7f88f' |
| status | BUILD |
| updated | 2019-10-13T21:23:44Z |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
| volumes_attached | |
+-----------------------------+---------------------------------------------+

stack@microwave:~$ openstack server show ubuntu-18.04_inst


+-----------------------------+----------------------------------------------------------+
| Field | Value |
+-----------------------------+----------------------------------------------------------+
| OS-DCF:diskConfig | MANUAL |
| OS-EXT-AZ:availability_zone | nova |
| OS-EXT-STS:power_state | Running |
| OS-EXT-STS:task_state | None |
| OS-EXT-STS:vm_state | active |
| OS-SRV-USG:launched_at | 2019-10-13T21:23:57.000000 |
| OS-SRV-USG:terminated_at | None |
| accessIPv4 | |
| accessIPv6 | |
| addresses | private=fdac:50a1:b51d:0:f816:3eff:fec8:2ed5, 10.0.0.43 |
| config_drive | |
| created | 2019-10-13T21:23:43Z |
| flavor | m1.small (2) |
| hostId | b3ce8aa16af22651ac4ab1291280fd727ff9c016c9068dcfcc861a75 |
| id | 01e719a0-abd4-44dd-99e1-27076de3dce5 |
| image | |
| key_name | LFO |
| name | ubuntu-18.04_inst |

90 Minutes avec OpenStack – 2019/11/11 37


| progress | 0 |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| properties | |
| security_groups | name='bastion_ssh' |
| status | ACTIVE |
| updated | 2019-10-13T21:23:58Z |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
| volumes_attached | id='edc26441-2f67-410d-8b24-a1e85844d8dc' |
+-----------------------------+----------------------------------------------------------+

Le lancement d’une instance tout comme la créa on d’un volume n’est pas immédiat, la commande
de créa on est lancée puis exécutée de façon asynchrone par les différents composants de
Openstack. La commande openstack server show permet de savoir quand l’instance est
fonc onnelle (« running »)

Ajout d’une adresse IP flo ante à notre instance


Par défaut dans notre projet nous avons au minimum deux réseaux, un réseau public (externe à notre
projet, il appar ent au système OpenStack) et un réseau privé (interne à notre projet) :
stack@microwave:~$ openstack network list
+--------------------------------------+---------+--------------------------------------+
| ID | Name | Subnets |
+--------------------------------------+---------+--------------------------------------+
| 0e6e2f0c-c4cc-4eca-8428-8117864b6e4a | private | 10b8dba4-4613-4462-b8f4-500bd6c7fc84 |
| 12ceb0b7-9ed6-4bfd-9160-ab44b4f868b2 | public | b3ee49a7-80b9-4898-8f53-a58cb1e3908c |
| 38f2e146-43e0-4f93-b3db-87fc25a4be19 | shared | 29ea72f8-7ac3-4d2a-a2f8-e4b2f2946718 |
+--------------------------------------+---------+--------------------------------------+

Pour le moment notre instance a une adresse IP dans le réseau « private » :


stack@microwave:~$ openstack server show ubuntu-18.04_inst
+-----------------------------+----------------------------------------------------------+
| Field | Value |
+-----------------------------+----------------------------------------------------------+
| OS-DCF:diskConfig | MANUAL |
| OS-EXT-AZ:availability_zone | nova |
| OS-EXT-STS:power_state | Running |
| OS-EXT-STS:task_state | None |
…/…
| id | 01e719a0-abd4-44dd-99e1-27076de3dce5 |
| name | ubuntu-18.04_inst |
…/…
| addresses | private=fdac:50a1:b51d:0:f816:3eff:fec8:2ed5, 10.0.0.43 |
…/…
| volumes_attached | id='edc26441-2f67-410d-8b24-a1e85844d8dc' |
+-----------------------------+----------------------------------------------------------+

Nous créons une adresse IP flo ante pour notre serveur, nous la créons dans le réseau « public » :
stack@microwave:~$ openstack floating ip create public
+---------------------+-------------------------------------------+
| Field | Value |
+---------------------+-------------------------------------------+
| created_at | 2019-10-14T18:42:24Z |
| description | |
| dns_domain | None |
| dns_name | None |
| fixed_ip_address | None |
| floating_ip_address | 172.24.4.105 |
| floating_network_id | 12ceb0b7-9ed6-4bfd-9160-ab44b4f868b2 |
| id | 168bd864-8489-4d50-96dd-24bd93f316e4 |
| name | 172.24.4.105 |
| port_details | None |
| port_id | None |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| qos_policy_id | None |
| revision_number | 0 |
| router_id | None |
| status | DOWN |
| subnet_id | None |
| tags | [] |
| updated_at | 2019-10-14T18:42:24Z |
+---------------------+-------------------------------------------+
stack@microwave:~$ openstack floating ip list
+--------------------------------------+---------------------+------------------+------+
| ID | Floating IP Address | Fixed IP Address | Port |
+--------------------------------------+---------------------+------------------+------+
| 168bd864-8489-4d50-96dd-24bd93f316e4 | 172.24.4.105 | None | None |

90 Minutes avec OpenStack – 2019/11/11 38


+--------------------------------------+---------------------+------------------+------+

Nous a achons maintenant l’adresse IP flo ante à notre instance :


stack@microwave:~$ openstack server add floating ip ubuntu-18.04_inst 172.24.4.105
stack@microwave:~$ openstack floating ip list
+--------------------------------------+---------------------+------------------+--------------------------------------+
| ID | Floating IP Address | Fixed IP Address | Port |
+--------------------------------------+---------------------+------------------+--------------------------------------+
| 168bd864-8489-4d50-96dd-24bd93f316e4 | 172.24.4.105 | 10.0.0.43 | 3db24397-cd2e-4cba-853a-e48ebcbd71e2 |
+--------------------------------------+---------------------+------------------+--------------------------------------+
stack@microwave:~$ openstack server list
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+
| ID | Name | Status | Networks | Image | Flavor |
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+
| 01e719a0-abd4-44dd-99e1-27076de3dce5 | ubuntu-18.04_inst | ACTIVE | private=10.0.0.43, 172.24.4.105 | | m1.small |
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+

Connexion à notre instance


Nous pouvons désormais nous connecter à notre instance :
stack@microwave:~$ ssh ubuntu@172.24.4.105
The authenticity of host '172.24.4.105 (172.24.4.105)' can't be established.
ECDSA key fingerprint is SHA256:i8oP2aoZrUSWHrpZ3mZBozhD4pG4GL9CCqizOMgHrGg.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.24.4.105' (ECDSA) to the list of known hosts.
Welcome to Ubuntu 18.04.3 LTS (GNU/Linux 4.15.0-65-generic x86_64)
…/…
ubuntu@ubuntu-18:~$ uname -a
Linux ubuntu-18 4.15.0-65-generic #74-Ubuntu SMP Tue Sep 17 17:06:04 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux

90 Minutes avec OpenStack – 2019/11/11 39


Les volumes de données
Nous l’avons vu, le contenu du volume système, c’est à dire le système d’exploita on et les logiciels
associés, sont « jetables », seules les données de l’applica on (bases de données, fichiers…) sont à
conserver de façon perenne.

Le volume système est celui sur lequel a été démarré l’instance, nous l’avons créé à par r d’une
image système mise à notre disposi on, les logiciels systèmes peuvent être installés et paramétrés de
façon automa que, nous verrons plus loin un exemple.

Nous créons un volume pour stocker des données, ce volume est créé de façon similaire au volume
système (sauf qu’il est créé vide, et non à par r d’une image). Ce volume est ensuite a aché à une
instance.

Créa on d’un volume de données via le Dashboard


Les volumes tout comme les instances appar ennent à un projet, il convient donc de se connecter
avec le bon u lisateur et de se placer dans le bon projet.

Dans le menu « Projet → Volumes → Volumes » nous voyons le volume système de notre instance,
son statut est « En cours d’u lisa on », il est a aché à notre instance sur le ‘device’ /dev/vda

Nous cliquons sur « Créer le volume » pour créer un nouveau volume :

Nous me ons « donnees » comme nom de volume, dans le champ « Source du volume » nous
me ons « Aucune source, volume vide », comme taille nous me ons 5 Go par exemple, puis nous
cliquons sur « Créer le volume » :

90 Minutes avec OpenStack – 2019/11/11 40


Le statut de notre nouveau volume est « disponible » :

Dans la liste déroulante à droite du volume « donnees »nous sélec onnons « Gérer les
a achements » :

90 Minutes avec OpenStack – 2019/11/11 41


Dans la liste « A acher à l’instance » nous sélec onnons notre instance « Ubuntu-18.04_inst », puis
nous cliquons sur « A acher le volume » :

L’a achement du volume prend quelques secondes, une fois l’a achement terminé nous voyons qu’il
est a aché en /dev/vdb :

90 Minutes avec OpenStack – 2019/11/11 42


Prépara on (par onnement et formatage) du volume
Nous nous connectons à notre instance, nous voyons le device /dev/vbd :
stack@microwave:~$ ssh ubuntu@172.24.4.105
Welcome to Ubuntu 18.04.3 LTS (GNU/Linux 4.15.0-65-generic x86_64)

ubuntu@ubuntu-18:~$ ls -l /dev/vd*
brw-rw---- 1 root disk 252, 0 Oct 13 21:24 /dev/vda
brw-rw---- 1 root disk 252, 1 Oct 13 21:24 /dev/vda1
brw-rw---- 1 root disk 252, 14 Oct 13 21:24 /dev/vda14
brw-rw---- 1 root disk 252, 15 Oct 13 21:24 /dev/vda15
brw-rw---- 1 root disk 252, 16 Oct 15 19:08 /dev/vdb

Afin de faciliter un éventuel agrandissement nous allons me re notre disque en LVM, nous
commençons par par onner le disque avec la commande fdisk, nous voyons ensuite le device
correspondant à notre par on (/dev/vdb1) :
ubuntu@ubuntu-18:~$ sudo fdisk /dev/vdb

Welcome to fdisk (util-linux 2.31.1).


Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table. ⇒ LE VOLUME N’EST PAS ENCORE PARTITIONNE
Created a new DOS disklabel with disk identifier 0xabdc88e0.

Command (m for help): n ⇒ n pour new


Partition type
p primary (0 primary, 0 extended, 4 free)
e extended (container for logical partitions)
Select (default p): p
Partition number (1-4, default 1): 1 ⇒ Partition 1
First sector (2048-10485759, default 2048): ⇒ Appuyer sur Entrée
Last sector, +sectors or +size{K,M,G,T,P} (2048-10485759, default 10485759): ⇒ Appuyer sur Entrée

Created a new partition 1 of type 'Linux' and of size 5 GiB.

Command (m for help): t ⇒ t pour type


Selected partition 1
Partition type (type L to list all types): 8e ⇒ 8e pour Linux LVM
Changed type of partition 'Linux' to 'Linux LVM'.

Command (m for help): p ⇒ p pour print (pour vérifier)


Disk /dev/vdb: 5 GiB, 5368709120 bytes, 10485760 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0xabdc88e0

Device Boot Start End Sectors Size Id Type


/dev/vdb1 2048 10485759 10483712 5G 8e Linux LVM

Command (m for help): w ⇒ w pour write, provoque la sortie du programme


The partition table has been altered.
Calling ioctl() to re-read partition table.
Syncing disks.

ubuntu@ubuntu-18:~$ ls -l /dev/vd*
brw-rw---- 1 root disk 252, 0 Oct 13 21:24 /dev/vda
brw-rw---- 1 root disk 252, 1 Oct 13 21:24 /dev/vda1
brw-rw---- 1 root disk 252, 14 Oct 13 21:24 /dev/vda14
brw-rw---- 1 root disk 252, 15 Oct 13 21:24 /dev/vda15
brw-rw---- 1 root disk 252, 16 Oct 15 19:14 /dev/vdb
brw-rw---- 1 root disk 252, 17 Oct 15 19:14 /dev/vdb

Nous créons un Physical Volume, un Logical Volume et nous le formatons en ext4 :


ubuntu@ubuntu-18:~$ sudo pvcreate /dev/vdb1
Physical volume "/dev/vdb1" successfully created

ubuntu@ubuntu-18:~$ sudo vgcreate PV_DONNEES /dev/vdb1


Volume group "PV_DONNEES" successfully created

ubuntu@ubuntu-18:~$ sudo lvcreate -l 100%FREE -n lv_donnees PV_DONNEES


Logical volume "lv_donnees" created.

ubuntu@ubuntu-18:~$ sudo mkfs.ext4 /dev/mapper/PV_DONNEES-lv_donnees


mke2fs 1.44.1 (24-Mar-2018)
Creating filesystem with 1309696 4k blocks and 327680 inodes
Filesystem UUID: eae55076-b853-4d6d-9a83-3d2258b5633b
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736

90 Minutes avec OpenStack – 2019/11/11 43


Allocating group tables: done
Writing inode tables: done
Creating journal (16384 blocks): done
Writing superblocks and filesystem accounting information: done

Nous créons le point montage, modifions le fichier /etc/fstab, montons le système de fichiers et
nous créons un fichier de test :
ubuntu@ubuntu-18:~$ sudo mkdir /DONNEES

ubuntu@ubuntu-18:~$ sudo tee /etc/fstab << EOF


/dev/mapper/PV_DONNEES-lv_donnees /DONNEES ext4 defaults 1 2
EOF
/dev/mapper/PV_DONNEES-lv_donnees /DONNEES ext4 defaults 1 2

ubuntu@ubuntu-18:~$ sudo mount /DONNEES

ubuntu@ubuntu-18:~$ df -h /DONNEES
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/PV_DONNEES-lv_donnees 4.9G 20M 4.6G 1% /DONNEES

ubuntu@ubuntu-18:~$ sudo tee /DONNEES/hello.txt << EOF


Hello
EOF

Le par onnement du volume et le formatage du volume logique provoquent la perte des


données existantes. Les commandes correspondantes demandent confirma on s’il y a un
risque que des données soient présentes.

Détachement du volume via le Dashboard


Depuis le Dashboard il est possible de détacher le volume de l’instance à laquelle il est a aché en
u lisant le menu déroulant à droite du volume dans la liste des volumes.

Détacher un volume revient à débrancher un disque dur d’un serveur physique, s’il était
encore monté par le système d’exploita on cela risquerai de provoquer une perte ou une
corrup on de données.

Cinder et Nova n’ont pas possibilité de savoir si le volume est monté par le système
d’exploita on de l’instance, aussi il convient de vérifier avant de procéder au démontage.

Au cas où vous souhaiteriez démonter le volume, il faut démonter la par on et il est préférable de
procéder à la désac va on du volume group :
ubuntu@ubuntu-18:~$ sudo umount /DONNEES
ubuntu@ubuntu-18:~$ sudo vgchange /dev/mapper/PV_DONNEES -an
0 logical volume(s) in volume group "PV_DONNEES" now active

Suppression d’un volume via le Dashboard


Depuis le Dashboard il est possible de supprimer un volume en u lisant le menu déroulant à droite
du volume dans la liste des volumes, pour ceci il ne doit plus être a aché à aucun serveur.

La suppression d’un volume est irréversible, les données qu’il contenait sont défini vement
perdues

Nous ne détruisons pas le volume de données que nous venons de créer car nous allons le

90 Minutes avec OpenStack – 2019/11/11 44


réu liser plus loin.

Créa on et a achement d’un volume en ligne de commande


Il est également possible de créer un volume et de l’a acher à un serveur en ligne de commande.

On voit là aussi que la créa on d’un volume (même vide) n’est pas instantanée.

Le nom des volumes n’est pas unique, plusieurs volumes peuvent porter le même nom, si
on passe la commande en u lisant le nom et qu’il n’est pas unique une erreur va se
produire, dans ce cas il est obligatoire d’u liser l’ID unique du volume.

stack@microwave:~$ source devstack/openrc demo demo


stack@microwave:~$ openstack volume create --size 1 donnees_bis
+---------------------+--------------------------------------+
| Field | Value |
+---------------------+--------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | false |
| consistencygroup_id | None |
| created_at | 2019-10-15T19:21:36.000000 |
| description | None |
| encrypted | False |
| id | 140b7ad2-0485-4fea-9d63-16e91c5707a8 |
| multiattach | False |
| name | donnees_bis |
| properties | |
| replication_status | None |
| size | 1 |
| snapshot_id | None |
| source_volid | None |
| status | creating |
| type | lvmdriver-1 |
| updated_at | None |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
+---------------------+--------------------------------------+
stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| 140b7ad2-0485-4fea-9d63-16e91c5707a8 | donnees_bis | available | 1 | |
| e4539f36-09b7-4198-afc4-6766c5116e22 | donnees | in-use | 5 | Attached to ubuntu-18.04_inst on /dev/vdb |
| edc26441-2f67-410d-8b24-a1e85844d8dc | ubuntu-18.04_vol | in-use | 10 | Attached to ubuntu-18.04_inst on /dev/vda |
+--------------------------------------+------------------+-----------+------+--------------------------------------------
+stack@microwave:~$ openstack server list
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+
| ID | Name | Status | Networks | Image | Flavor |
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+
| 01e719a0-abd4-44dd-99e1-27076de3dce5 | ubuntu-18.04_inst | ACTIVE | private=10.0.0.43, 172.24.4.105 | | m1.small |
+--------------------------------------+-------------------+--------+---------------------------------+-------+----------+
stack@microwave:~$ openstack server add volume ubuntu-18.04_inst donnees_bis
stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+--------+------+--------------------------------------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+--------+------+--------------------------------------------+
| 140b7ad2-0485-4fea-9d63-16e91c5707a8 | donnees_bis | in-use | 1 | Attached to ubuntu-18.04_inst on /dev/vdc |
| e4539f36-09b7-4198-afc4-6766c5116e22 | donnees | in-use | 5 | Attached to ubuntu-18.04_inst on /dev/vdb |
| edc26441-2f67-410d-8b24-a1e85844d8dc | ubuntu-18.04_vol | in-use | 10 | Attached to ubuntu-18.04_inst on /dev/vda |
+--------------------------------------+------------------+--------+------+--------------------------------------------+

L’op on ‘-f json’ de la commande openstack permet d’afficher le résultat de la commande au


format JSON au lieu d’afficher le résultat sous forme de tableau. Le format est humainement lisible et
le résultat plus complet que sous forme de tableau :
stack@microwave:~$ openstack volume show donnees_bis -f json
{
"status": "in-use",
"properties": {},
"user_id": "57d02b0938d149a1aac96ce6757a3a14",
"description": null,
"availability_zone": "nova",
"bootable": "false",
"encrypted": false,
"created_at": "2019-10-15T19:21:36.000000",

90 Minutes avec OpenStack – 2019/11/11 45


"multiattach": false,
"updated_at": "2019-10-15T19:25:18.000000",
"source_volid": null,
"name": "donnees_bis",
"snapshot_id": null,
"consistencygroup_id": null,
"replication_status": null,
"os-vol-tenant-attr:tenant_id": "5cd4212611654857a9e941a7b5d35e13",
"size": 1,
"type": "lvmdriver-1",
"id": "140b7ad2-0485-4fea-9d63-16e91c5707a8",
"attachments": [
{
"server_id": "01e719a0-abd4-44dd-99e1-27076de3dce5",
"attachment_id": "30162df5-3788-4aff-a3b7-a743beec55a9",
"attached_at": "2019-10-15T19:25:17.000000",
"host_name": "microwave",
"volume_id": "140b7ad2-0485-4fea-9d63-16e91c5707a8",
"device": "/dev/vdc",
"id": "140b7ad2-0485-4fea-9d63-16e91c5707a8"
}
]
}

Détachement et suppression d’un volume en ligne de commande


Nous pouvons détacher le deuxième volume du serveur puis détruire le volume :
stack@microwave:~$ openstack server remove volume ubuntu-18.04_inst donnees_bis
stack@microwave:~$ openstack volume delete donnees_bis
stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+--------+------+--------------------------------------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+--------+------+--------------------------------------------+
| e4539f36-09b7-4198-afc4-6766c5116e22 | donnees | in-use | 5 | Attached to ubuntu-18.04_inst on /dev/vdb |
| edc26441-2f67-410d-8b24-a1e85844d8dc | ubuntu-18.04_vol | in-use | 10 | Attached to ubuntu-18.04_inst on /dev/vda |
+--------------------------------------+------------------+--------+------+--------------------------------------------+

Il vous est laissé à tre d’exercice de vérifier si le filesystem du volume ‘donnees’ a été
démonté en vous connectant à l’instance puis de détacher le volume de l’instance (s’il n’a
pas été démonté la commande de démontage et de désac va on du volumegroup est
indiquée un peu plus haut).

Ne détruisez pas le volume ‘donnees’ il va resservir.

90 Minutes avec OpenStack – 2019/11/11 46


L’orchestra on
L’orchestra on est une des fonc onnalités puissantes du Cloud, elle permet de déployer des
infrastructures de manière automa que et reproduc ble, elle se base sur un langage de descrip on
des infrastructures et un langage de template (modèles).

L’orchestra on permet aussi d’assurer l’élas cité, c’est à dire de faire varier les infrastructures en
fonc on de la charge.

Différents systèmes d’orchestra on existent, ceci grâce à l’ouverture des API OpenStack.

L’orchestra on avec Heat


Heat est un des projets de OpenStack.

Heat permet de décrire les infrastructures sous forme de fichier texte, l’infrastructure peut
comprendre la plupart des types de ressources (instances, volumes, routeurs, réseaux…)

La descrip on d’une infrastructure pour Heat s’appelle un template (modèle). Déployer un template
dans un tenant (éventuellement avec des paramètres) va créer une « pile » de ressources.

Heat est composé :

• d’un service en charge de synchroniser les opéra ons nécessaires à la créa on de


l’infrastructure décrite

• d’une API

• d’une interface en ligne de commande qui s’intègre à la commande CLI openstack.

Un template de base est composé de 4 par es :

• Une descrip on du template, à tre purement documentaire

• Un ensemble de paramètres qui perme ent d’adapter le template lors de chaque


déploiement et de créer une pile adaptée au client et à l’environnement, ces paramètres ont
une valeur par défaut qui peut être écrasée lors de la créa on de la pile, soit depuis des
champs de saisie dans le Dashboard, soit par des paramètres passés en ligne de commande
lors de la créa on de la pile à l’aide du CLI openstack

• Un ensemble de ressources qui vont être créées et liées les unes aux autres (des volumes aux
serveurs, des interfaces à des réseaux…)

• Des sor es qui vont nous perme re de récupérer des informa ons sur la pile créée (adresses
IP, URL...), ces données sont décrites et mises en forme dans la pile

Les ressources
On l’a dit, une pile est composée de ressources, ce sont les objets que l’on peut créer dans
OpenStack, la pile décrit également les liaisons entre ces ressources.

90 Minutes avec OpenStack – 2019/11/11 47


Ces ressources sont définies par un type, par exemple une instance est de type
OS::Nova::Server (OS car il s’agit d’un objet de OpenStack, Nova car Nova est le composant de
OpenStack qui gère les serveurs), OS::Nova::KeyPair est une paire de clé. Il existe également
des objets de type AWS:: pour assurer la compa bilité avec AWS, le cloud de Amazon.

Dans le Dashboard on retrouve les différents types d’objets disponibles ainsi que leur documenta on
succincte dans le menu « Projet → Orchestra on → Type de ressources ».

90 Minutes avec OpenStack – 2019/11/11 48


Une première pile
Notre premier template va être simple, il va créer une instance à par r de l’image Ubuntu que nous
avons chargée dans OpenStack, et un script bash va être u lisé pour installer deux packages logiciels
et exécuter deux commandes.

Recopiez le template ci-dessous dans un fichier que vous appellerez premiere_stack.yaml, il


est également disponible à ce e adresse : h ps://u03.fr/90openstack/premiere_stack.yaml
heat_template_version: 2013-05-23

description: >
Notre premiere pile Heat

parameters:
nom_de_cle:
type: string
description: Nom de la cle

gabarit_instance:
type: string
description:
default: m1.small

image_instance:
type: string
description: Nom de l'image
default: ubuntu-18.04

reseau_instance:
type: string
description: Nom du reseau de raccordement de l'instance
default: private

resources:
instance_heat:
type: OS::Nova::Server
properties:
image: { get_param: image_instance }
flavor: { get_param: gabarit_instance }
key_name: { get_param: nom_de_cle }
networks:
- network: { get_param: reseau_instance }
user_data: |
#!/bin/bash -v

apt-get update
apt-get install -y cowsay fortune
/usr/games/fortune | /usr/games/cowsay
/usr/games/fortune | /usr/games/cowsay > /dev/tty1
cat << EOF >> /home/ubuntu/.bashrc
/usr/games/fortune | /usr/games/cowsay
EOF

outputs:
salutations:
description: La salutation du jour
value: Hello World!!!

On y retrouve les 4 par es (« description », « parameters », « ressources » et


« outputs »).

Dans la sec on « ressources » nous n’avons qu’une ressource, il s’agit d’une instance de
serveur, son iden fiant est « instance_heat », grâce à cet iden fiant, u lisable uniquement dans
la défini on de pile, la ressource pourra être référencée ailleurs dans la pile (dans la défini on
d’autres ressources ou dans la sec on « outputs »).

Le type de la ressource est « OS::Nova::Server », ses propriétés sont :

• image : le nom de l’image, ce nom provient du paramètre « image_instance »

• flavor : il s’agit du gabarit, ce nom provient du paramètre « gabarit_instance »

90 Minutes avec OpenStack – 2019/11/11 49


• key_name : le nom de la paire de clé u lisée pour se connecter en SSH à l’instance, une clé
avec ce nom doit être enregistrée dans le projet

• user_data : ce champ s’étend sur plusieurs lignes (grâce au « | », il s’agit du script qui va
s’exécuter au moment du lancement de l’instance, ici ce champ est constant mais nous
verrons qu’il est possible de modifier ce champ en fonc on des valeurs des paramètres
passés lors de la créa on de la pile.

La ligne heat_template_version: 2013-05-23 ne correspond pas à la version du


template, mais à la version du langage de template u lisée, ce qui correspond à la version
d’OpenStack pour laquelle le template a été ini alement écrit. N’essayez donc pas d’y
me re la date du jour par exemple.

U lisa on de la pile
L’u lisa on des piles se fait dans le Dashboard dans le menu « Projet → Orchestra on → Piles », pour
lancer une pile il faut cliquer sur le bouton « Lancer la pile » :

La source du modèle (le template) est premiere_stack.yaml, (disponible un peu plus haut dans
le document ou à l’adresse h ps://u03.fr/90openstack/premiere_stack.yaml). Vous pouvez au choix
u liser une copie locale sur votre poste de travail (source du modèle ‘Fichier’ et cliquez sur
« Parcourir »), soit u liser directement le fichier via son URL. Le « champ environnement » permet de
sélec onner un fichier de paramètres qui vont venir écraser les paramètres par défaut spécifiés dans
le template, nous ne l’u lisons pas pour le moment. Cliquez sur « Suivant » :

90 Minutes avec OpenStack – 2019/11/11 50


Nous allons nommer notre pile « ma_pile », nous tapons notre mot de passe dans le champ prévu
à cet effet, et nous tapons le nom de notre clé SSH dans le champ « nom_de_cle » puis nous
cliquons sur « Démarrer » :

La créa on de la pile va demander environ une minute :

90 Minutes avec OpenStack – 2019/11/11 51


En cliquant sur « ma_pile » nous affichons par défaut la « topologie » de notre pile, elle est simple, il
n’y a que notre serveur.

Nous voyons que l’écran « ma_pile » est composé de 5 onglets « Topologie » , « Vue d’ensemble »,
« Ressources », « Événements » et « Modèle ».

L’onglet « Vue d’ensemble » nous donne les informa ons essen elles sur la pile, on y retrouve la
descrip on présente dans la défini on de la pile, l’état de la pile, les paramètres qui ont été passés et
les sor es (Outputs) qui ont été définies dans la pile dans la sec on « outputs », nous retrouvons ici
nos saluta ons :

90 Minutes avec OpenStack – 2019/11/11 52


L’onglet « Ressouces » donne les différentes ressources qui composent notre pile, ici nous n’avons
qu’un serveur, dont le nom est « instance_heat » dans la défini on de notre pile :

Si nous cliquons sur l’iden fiant en hexadécimal de notre instance nous allons nous retrouver sur
l’écran de vue d’ensemble de notre instance, de la même manière que si vous avions cliqué dessus
dans l’écran « Projet → Compute → Instances ».

On aperçoit au passage que le nom de notre instance est composé du nom de la pile, du nom de la
ressource dans la pile et d’une chaîne de caractères aléatoires, nous aurions pu donner un nom à
ce e instance en u lisant l’a ribut « name » dans la défini on de la ressource :

90 Minutes avec OpenStack – 2019/11/11 53


Cliquer sur l’onglet « console » nous affiche la console, on peut y voir une vache qui prononce une
phrase amusante en anglais (cliquez dans la par e noire de l’écran puis tapez sur la touche espace si
l’écran de la console est entré en veille) :

Il vous est laissé à tre d’exercice depuis le Dashboard d’a acher une adresse IP flo ante à
l’instance, d’autoriser la connexion SSH dans les groupes de sécurité et de vous connecter à
l’instance avec l’u lisateur ubuntu, vous serez également accueilli par la vache.

Suppression de la pile
Dans le menu « Projet → Orchestra on → Piles » il est possible de supprimer la pile en u lisant le
menu déroulant à droite de la pile.

90 Minutes avec OpenStack – 2019/11/11 54


La suppression d’une pile entraîne la suppression de la totalité des éléments créés par la
pile, il s’agit d’une opéra on irréversible.

Autres types de ressources de Heat


Nous avons créé une première pile qui comportait juste une instance de base et u lisait quelques
paramètres.

D’autres types de ressources perme ent de construire des infrastructures plus évoluées.

Créa on d’une groupe de sécurité et d’une adresse IP flo ante


Nous allons voir comment créer un groupe de sécurité et l’a acher ainsi qu’une adresse IP flo ante à
notre instance.

Le groupe de sécurité de sécurité est créé en même temps que les règles (ici il y a une seule règle qui
autorise les accès en SSH (tcp port 22), en entrée (ingress), depuis toutes les adresses IP (0.0.0.0/0).

Le groupe de sécurité est ensuite a achée à l’instance avec la propriété security_groups de


l’instance gràace à get_resource :
instance_heat_security_group:
type: OS::Neutron::SecurityGroup
properties:
rules:
- remote_ip_prefix: 0.0.0.0/0
protocol: tcp
port_range_min: 22
port_range_max: 22
direction: ingress

[…/…]
instance_heat:
type: OS::Nova::Server
security_groups: [{ get_resource: instance_heat_security_group }]

La ges on de l’adresse IP flo ante est différente, on crée une adresse IP flo ante


(OS::Neutron::FloatingIP) dans le réseau ‘public’ et on crée une deuxième ressource qui
est une associa on d’adresse IP flo ante (OS::Nova::FloatingIPAssociation)
floating_ip_instance_heat:
type: OS::Neutron::FloatingIP
properties:
floating_network: { get_param: reseau_public }

association_reverseproxy:
type: OS::Nova::FloatingIPAssociation
properties:
floating_ip: { get_resource: floating_ip_instance_heat }
server_id: { get_resource: instance_heat }

L’adresse IP flo ante du serveur va être a ribuée par le système, nous pouvons modifier la sec on
« outputs » pour afficher l’adresse IP qui a été a ribuée :
outputs:
instance_heat_public_ip:
description: Adresse IP publique de l'instance Heat
value: { get_attr: [ floating_ip_instance_heat, floating_ip_address ] }

La pile complète est disponible à ce e adresse :

• h ps://u03.fr/90openstack/groupe_securite_ip.yaml

90 Minutes avec OpenStack – 2019/11/11 55


Une fois la créa on de la pile terminée nous avons l’adresse IP flo ante qui a été a ribuée dans
l’onglet « Vue d’ensemble de la pile » :

Nous pouvons désormais nous connecter en SSH à notre serveur en u lisant l’adresse IP flo ante qui
lui a été allouée :
stack@microwave:~$ ssh ubuntu@172.24.4.144
The authenticity of host '172.24.4.6 (172.24.4.6)' can't be established.
ECDSA key fingerprint is SHA256:Bw5AKL7SQk+AfMXSv1WUQAAMt9u3eQHC3W2Dx8vEjhY.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.24.4.144' (ECDSA) to the list of known hosts.
Welcome to Ubuntu 18.04.3 LTS (GNU/Linux 4.15.0-65-generic x86_64)
____________________________________
/ You are confused; but this is your \
\ normal state. /
------------------------------------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
ubuntu@ip-flottante-instance-heat-a4sp3gehehc4:~$

L’inconvénient de créer l’adresse IP flo ante dans la pile est que celle-ci est libérée lors de la
destruc on de la pile, et lors de la recréa on de la pile une nouvelle adresse IP sera allouée.

Cela rend impossible la créa on d’entrées DNS qui pointent vers l’applica on.

C’est pour cela qu’on alloue les IP flo antes en dehors de la pile et qu’on les associe au
serveur dans la pile.

Il vous est laissé à tre d’exercice de supprimer la pile.

U lisa on d’une adresse IP flo ante


Ci-dessous la créa on de l’adresse IP flo ante, la défini on du paramètre dans la pile, et l’associaton
de l’adresse IP flo ante au serveur. Globalement on u lise ‘get-param’ au lieu d’un ‘get-
ressource’.
stack@microwave:~$ openstack floating ip create public
+---------------------+--------------------------------------+

90 Minutes avec OpenStack – 2019/11/11 56


| Field | Value |
+---------------------+--------------------------------------+
| created_at | 2018-03-26T17:38:04Z |
| description | |
| fixed_ip_address | None |
| floating_ip_address | 172.24.4.14 |
| floating_network_id | 087bc8a1-65e2-4747-b96e-4dd421c542e5 |
| id | dd92bcbc-77a5-4624-bf3b-b02489da4ee1 |
| name | 172.24.4.14 |
| port_id | None |
| project_id | 3f36cd33d14e468293caa7bf311c00de |
| qos_policy_id | None |
| revision_number | 0 |
| router_id | None |
| status | DOWN |
| subnet_id | None |
| updated_at | 2018-03-26T17:38:04Z |
+---------------------+--------------------------------------+

parameters:
id_floating_ip_reverseproxy:
type: string
description: ID de la floating IP pour le reverse-proxy
default: dd92bcbc-77a5-4624-bf3b-b02489da4ee1

resources:
association_reverseproxy:
type: OS::Nova::FloatingIPAssociation
properties:
floating_ip: { get_param: id_floating_ip_reverseproxy }
server_id: { get_resource: instance_reverseproxy }

Créa on d’un volume à par r d’une image


Comme nous l’avons vu, l’orchestra on permet de déployer automa quement des infrastructures, en
par culier pour des mises à jour du système ou de l’applica on.

Pour ceci il est possible de redéployer des serveurs à par r d’une image système mise à jour. Tout
comme nous l’avions fait à par r du Dashboard :
instance_heat_volume:
type: OS::Cinder::Volume
properties:
size: 10
name: instance_heat_volume
image: { get_param: image_instance }

Le volume est ensuite une ressource u lisable dans la défini on d’une instance, grâce à la propriété
block_device_mapping de l’instance, « get_ressource » perme ant de référencer la
ressource correspondant au volume par son iden fiant :
instance_heat:
type: OS::Nova::Server
properties:
name: une_instance
flavor: { get_param: instance_type_heat }
block_device_mapping: [{ device_name: "vda", volume_id : { get_resource : instance_heat_volume } }]

La pile est disponible à ce e adresse : h ps://u03.fr/90openstack/volume_systeme.yaml

Il vous est laissé à tre d’exercice créer la pile, de vous connecter au serveur et de
supprimer la pile.

A achement d’un volume de données à une instance


Les volumes de données con ennent les données persistantes de l’applica on, lors du redéploiement
de l’applica on il faut les ré-a acher aux instances concernées.

90 Minutes avec OpenStack – 2019/11/11 57


L’a achement du volume système dans l’exemple précédent se faisait en u lisant get_resource
pour récupérer l’id du volume créé par la pile.

L’a achement est le même que pour le volume système, sauf que la valeur de l’id va être passée en
paramètre :
parameters:
id_volume_donnees:
type: string
description: ID du volume de donnees a attacher

[…/…]

Nous allons réu liser le volume que nous avions créé précédemment et qui s’appelait « donnees »,
l’a achement se faisant par id du volume (car seuls les id sont uniques dans le système), nous
obtenons son iden fiant depuis le Dashboard ou en ligne de commande :
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| e4539f36-09b7-4198-afc4-6766c5116e22 | donnees | available | 5 | |
| edc26441-2f67-410d-8b24-a1e85844d8dc | ubuntu-18.04_vol | in-use | 10 | Attached to ubuntu-18.04_inst on /dev/vda |
+--------------------------------------+------------------+-----------+------+--------------------------------------------+

La pile complète est disponible à ce e adresse : h ps://u03.fr/90openstack/volume_donnees.yaml

Nous avions créé un fichier de test dans le volume de données lors de sa créa on, nous le retrouvons
dans notre instance :
ubuntu@pile-instance-heat-vfn4bx77nznj:~$ df -h /DONNEES/
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/PV_DONNEES-lv_donnees 4.8G 10M 4.6G 1% /DONNEES
ubuntu@pile-instance-heat-vfn4bx77nznj:~$ cat /DONNEES/hello.txt
Hello

90 Minutes avec OpenStack – 2019/11/11 58


U lisa on des piles à l’aide du CLI openstack
Toutes les opéra ons sous OpenStack sont effectuées grâce aux API, le Dashboard et le CLI OpenStack
sont deux des moyens d’u liser ces API, il est donc possible d’u liser le CLI OpenStack pour gérer les
piles.

Lancement d’une pile


Nous spécifions les différents paramètres sur la ligne de commande, la créa on d’une pile est
asynchrone et prend un certain temps en fonc on des ressources à créer :
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack stack create --wait \
--parameter nom_de_cle="LFO" \
--parameter id_volume_donnees="e4539f36-09b7-4198-afc4-6766c5116e22" \
-t https://u03.fr/90openstack/volume_donnees.yaml \
ma_pile_donnees
2019-10-19 20:31:04Z [ma_pile_donnees]: CREATE_IN_PROGRESS Stack CREATE started
2019-10-19 20:31:04Z [ma_pile_donnees.instance_heat_volume]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:06Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:06Z [ma_pile_donnees.instance_heat_security_group]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:07Z [ma_pile_donnees.instance_heat_security_group]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.instance_heat_volume]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:38Z [ma_pile_donnees.instance_heat]: CREATE_COMPLETE state changed
2019-10-19 20:31:38Z [ma_pile_donnees.association_reverseproxy]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:45Z [ma_pile_donnees.association_reverseproxy]: CREATE_COMPLETE state changed
2019-10-19 20:31:45Z [ma_pile_donnees]: CREATE_COMPLETE Stack CREATE completed successfully
+---------------------+-------------------------------------------------------------------------------+
| Field | Value |
+---------------------+-------------------------------------------------------------------------------+
| id | 41325438-8de5-473e-b310-b54f42bd586f |
| stack_name | ma_pile_donnees |
| description | Creation d'un volume systeme a partir d'une image et attachement a l'instance |
| | |
| creation_time | 2019-10-19T20:31:04Z |
| updated_time | None |
| stack_status | CREATE_COMPLETE |
| stack_status_reason | Stack CREATE completed successfully |
+---------------------+-------------------------------------------------------------------------------+

Une fois la créa on de la pile terminée nous retrouvons les données présentes dans la sec on
« outputs » de la défini on de notre pile :
stack@microwave:~$ openstack stack show ma_pile_donnees
+-----------------------+-------------------------------------------------------------------------------+
| Field | Value |
+-----------------------+-------------------------------------------------------------------------------+
| id | 41325438-8de5-473e-b310-b54f42bd586f |
| stack_name | ma_pile_donnees |
| description | Creation d'un volume systeme a partir d'une image et attachement a l'instance |
| | |
| creation_time | 2019-10-19T20:31:04Z |
| updated_time | None |
| stack_status | CREATE_COMPLETE |
| stack_status_reason | Stack CREATE completed successfully |
| parameters | OS::project_id: 5cd4212611654857a9e941a7b5d35e13 |
| | OS::stack_id: 41325438-8de5-473e-b310-b54f42bd586f |
| | OS::stack_name: ma_pile_donnees |
| | gabarit_instance: m1.small |
| | id_volume_donnees: e4539f36-09b7-4198-afc4-6766c5116e22 |
| | image_instance: ubuntu-18.04 |
| | nom_de_cle: LFO |
| | reseau_instance: private |
| | reseau_public: public |
| | |
| outputs | - description: Adresse IP publique de l'instance Heat |
| | output_key: instance_heat_public_ip |
| | output_value: 172.24.4.166 |
| | |
| parent | None |
| disable_rollback | True |
| deletion_time | None |
| stack_user_project_id | 18bddd0b6d314b2faf056b0b3ebc50f0 |
| capabilities | [] |
| notification_topics | [] |
| stack_owner | None |
| timeout_mins | None |
| tags | None |
+-----------------------+-------------------------------------------------------------------------------+

90 Minutes avec OpenStack – 2019/11/11 59


Il est possible de lister les différentes ressources qui composent notre pile, notez au passage
comment il est possible de sélec onner les colonnes affichées:
stack@microwave:~$ openstack stack resource list ma_pile_donnees \
-c resource_name -c physical_resource_id -c resource_type -c resource_status
+------------------------------+--------------------------------------+---------------------------------+-----------------+
| resource_name | physical_resource_id | resource_type | resource_status |
+------------------------------+--------------------------------------+---------------------------------+-----------------+
| instance_heat | 2d8cad6c-e75d-44f1-acc9-48e61459b0a7 | OS::Nova::Server | CREATE_COMPLETE |
| instance_heat_volume | 79f521fa-daca-4699-80a8-0ceaf8e941d5 | OS::Cinder::Volume | CREATE_COMPLETE |
| floating_ip_instance_heat | b88cf79f-1a54-4971-9cd9-f2b7f50fa08f | OS::Neutron::FloatingIP | CREATE_COMPLETE |
| association_reverseproxy | 19 | OS::Nova::FloatingIPAssociation | CREATE_COMPLETE |
| instance_heat_security_group | 503bfcc6-892b-45d3-ad43-ea033e7a5ff4 | OS::Neutron::SecurityGroup | CREATE_COMPLETE |
+------------------------------+--------------------------------------+---------------------------------+-----------------+

Il est ensuite possible d’afficher une ressource par culière à l’aide de la commande ci-dessous :
stack@microwave:~$ openstack stack resource show ma_pile_donnees instance_heat_volume

Vous pouvez aussi obtenir la liste des évènements liées à la pile :


stack@microwave:~$ openstack stack event list ma_pile_donnees
2019-10-19 20:31:04Z [ma_pile_donnees]: CREATE_IN_PROGRESS Stack CREATE started
2019-10-19 20:31:04Z [ma_pile_donnees.instance_heat_volume]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:06Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:06Z [ma_pile_donnees.instance_heat_security_group]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:07Z [ma_pile_donnees.instance_heat_security_group]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.instance_heat_volume]: CREATE_COMPLETE state changed
2019-10-19 20:31:09Z [ma_pile_donnees.instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:38Z [ma_pile_donnees.instance_heat]: CREATE_COMPLETE state changed
2019-10-19 20:31:38Z [ma_pile_donnees.association_reverseproxy]: CREATE_IN_PROGRESS state changed
2019-10-19 20:31:45Z [ma_pile_donnees.association_reverseproxy]: CREATE_COMPLETE state changed
2019-10-19 20:31:45Z [ma_pile_donnees]: CREATE_COMPLETE Stack CREATE completed successfully

Mise à jour d’une pile


Il est possible de me re à jour une pile (lorsque certains paramètres ou défini ons ont été modifiés),
lors de la mise à jour de la pile les ressources dont la défini on a été modifiée sont détruits et
recréés.

Nous ajoutons une règle dans le groupe de sécurité pour ajouter le port 80 :
instance_heat_security_group:
type: OS::Neutron::SecurityGroup
properties:
rules:
- remote_ip_prefix: 0.0.0.0/0
protocol: tcp
port_range_min: 22
port_range_max: 22
direction: ingress
- remote_ip_prefix: 0.0.0.0/0
protocol: tcp
port_range_min: 80
port_range_max: 80
direction: ingress

La pile mise à jour est disponible à ce e adresse :

• h ps://u03.fr/90openstack/volume_donnees_update.yaml

Nous me ons à jour la pile :


stack@microwave:~$ openstack stack update --wait \
--parameter nom_de_cle="LFO" \
--parameter id_volume_donnees="e4539f36-09b7-4198-afc4-6766c5116e22" \
-t https://u03.fr/90openstack/volume_donnees_update.yaml \
ma_pile_donnees
2019-10-19 20:41:08Z [ma_pile_donnees]: UPDATE_IN_PROGRESS Stack UPDATE started
2019-10-19 20:41:10Z [ma_pile_donnees.instance_heat_security_group]: UPDATE_IN_PROGRESS state changed
2019-10-19 20:41:12Z [ma_pile_donnees.instance_heat_security_group]: UPDATE_COMPLETE state changed
2019-10-19 20:41:13Z [ma_pile_donnees]: UPDATE_COMPLETE Stack UPDATE completed successfully
+---------------------+-------------------------------------------------------------------------------+
| Field | Value |
+---------------------+-------------------------------------------------------------------------------+

90 Minutes avec OpenStack – 2019/11/11 60


| id | 41325438-8de5-473e-b310-b54f42bd586f |
| stack_name | ma_pile_donnees |
| description | Creation d'un volume systeme a partir d'une image et attachement a l'instance |
| | |
| creation_time | 2019-10-19T20:31:04Z |
| updated_time | 2019-10-19T20:41:08Z |
| stack_status | UPDATE_COMPLETE |
| stack_status_reason | Stack UPDATE completed successfully |
+---------------------+-------------------------------------------------------------------------------+
stack@microwave:~$ openstack stack list
+--------------------------------------+-----------------+-----------------+----------------------+----------------------+
| ID | Stack Name | Stack Status | Creation Time | Updated Time |
+--------------------------------------+-----------------+-----------------+----------------------+----------------------+
| 41325438-8de5-473e-b310-b54f42bd586f | ma_pile_donnees | UPDATE_COMPLETE | 2019-10-19T20:31:04Z | 2019-10-19T20:41:08Z |
+--------------------------------------+-----------------+-----------------+----------------------+----------------------+

Vérifions la bonne mise à jour du groupe de sécurité :


stack@microwave:~$ openstack stack resource list ma_pile_donnees \
-c resource_name -c physical_resource_id -c resource_type -c resource_status
+------------------------------+--------------------------------------+---------------------------------+-----------------+
| resource_name | physical_resource_id | resource_type | resource_status |
+------------------------------+--------------------------------------+---------------------------------+-----------------+
| instance_heat | 2d8cad6c-e75d-44f1-acc9-48e61459b0a7 | OS::Nova::Server | CREATE_COMPLETE |
| instance_heat_volume | 79f521fa-daca-4699-80a8-0ceaf8e941d5 | OS::Cinder::Volume | CREATE_COMPLETE |
| floating_ip_instance_heat | b88cf79f-1a54-4971-9cd9-f2b7f50fa08f | OS::Neutron::FloatingIP | CREATE_COMPLETE |
| association_reverseproxy | 19 | OS::Nova::FloatingIPAssociation | CREATE_COMPLETE |
| instance_heat_security_group | 503bfcc6-892b-45d3-ad43-ea033e7a5ff4 | OS::Neutron::SecurityGroup | UPDATE_COMPLETE |
+------------------------------+--------------------------------------+---------------------------------+-----------------+
stack@microwave:~$ openstack security group show 503bfcc6-892b-45d3-ad43-ea033e7a5ff4
+-----------------+--------------------------------------------------------------------------------+
| Field | Value |
+-----------------+--------------------------------------------------------------------------------+
| created_at | 2019-10-19T20:31:06Z |
| description | |
| id | 503bfcc6-892b-45d3-ad43-ea033e7a5ff4 |
| name | ma_pile_donnees-instance_heat_security_group-u2b577tcgwak |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| revision_number | 9 |
| rules | direction='egress', ethertype='IPv4' |
| | direction='egress', ethertype='IPv6' |
| | direction='ingress', ethertype='IPv4', |
| | protocol='tcp', port_range_max='22', port_range_min='22', |
| | remote_ip_prefix='0.0.0.0/0' |
| | direction='ingress', ethertype='IPv4', |
| | protocol='tcp', port_range_max='80', port_range_min='80', |
| | remote_ip_prefix='0.0.0.0/0' |
| | |
| tags | [] |
| updated_at | 2019-10-19T20:41:11Z |
+-----------------+--------------------------------------------------------------------------------+

Destruc on d’une pile


Nous pouvons détruite une pile en ligne de commande, une confirma on est demandée car la
destruc on d’un pile peut provoquer la destruc on d’un grand nombre de ressources, le paramètre
« -y » permet d’outrepasser la confirma on. La destruc on d’une pile est irréversible même si elle
n’est pas immédiate :
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack stack delete ma_pile_donnees --wait
Are you sure you want to delete this stack(s) [y/N]? y
2019-10-19 20:49:26Z [ma_pile_donnees]: DELETE_IN_PROGRESS Stack DELETE started
2019-10-19 20:49:26Z [ma_pile_donnees.association_reverseproxy]: DELETE_IN_PROGRESS state changed
2019-10-19 20:49:28Z [ma_pile_donnees.association_reverseproxy]: DELETE_COMPLETE state changed
2019-10-19 20:49:28Z [ma_pile_donnees.floating_ip_instance_heat]: DELETE_IN_PROGRESS state changed
2019-10-19 20:49:28Z [ma_pile_donnees.instance_heat]: DELETE_IN_PROGRESS state changed
2019-10-19 20:49:32Z [ma_pile_donnees.floating_ip_instance_heat]: DELETE_COMPLETE state changed
2019-10-19 20:49:38Z [ma_pile_donnees.instance_heat]: DELETE_COMPLETE state changed
2019-10-19 20:49:38Z [ma_pile_donnees.instance_heat_volume]: DELETE_IN_PROGRESS state changed
2019-10-19 20:49:38Z [ma_pile_donnees.instance_heat_security_group]: DELETE_IN_PROGRESS state changed
2019-10-19 20:49:39Z [ma_pile_donnees.instance_heat_security_group]: DELETE_COMPLETE state changed
2019-10-19 20:49:40Z [ma_pile_donnees.instance_heat_volume]: DELETE_COMPLETE state changed
2019-10-19 20:49:40Z [ma_pile_donnees]: DELETE_COMPLETE Stack DELETE completed successfully
stack@microwave:~$ openstack stack list
⇒ Vide

Lancement d’une pile avec un fichier de paramètres


Nous créons fichier de paramètres que nous appelons env.yaml, adaptez le fichier à votre
environnement (nom de la clé et ID de votre volume de données) :

90 Minutes avec OpenStack – 2019/11/11 61


parameter_defaults:
nom_de_cle: LFO
id_volume_donnees: e4539f36-09b7-4198-afc4-6766c5116e22

Nous u lisons le paramètre « -e » qui permet de spécifier un fichier d’environnement, le paramètre


« --wait » permet d’a endre la fin de la créa on de la pile et de suivre sa progression :
stack@microwave:~$ openstack stack create --wait \
-e env.yaml -t https://u03.fr/90openstack/volume_donnees.yaml \
ma_pile_donnees
2019-10-20 12:07:08Z [ma_pile_donnees]: CREATE_IN_PROGRESS Stack CREATE started
2019-10-20 12:07:08Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-20 12:07:09Z [ma_pile_donnees.instance_heat_security_group]: CREATE_IN_PROGRESS state changed
2019-10-20 12:07:10Z [ma_pile_donnees.instance_heat_security_group]: CREATE_COMPLETE state changed
2019-10-20 12:07:10Z [ma_pile_donnees.instance_heat_volume]: CREATE_IN_PROGRESS state changed
2019-10-20 12:07:11Z [ma_pile_donnees.floating_ip_instance_heat]: CREATE_COMPLETE state changed
2019-10-20 12:07:15Z [ma_pile_donnees.instance_heat_volume]: CREATE_COMPLETE state changed
2019-10-20 12:07:15Z [ma_pile_donnees.instance_heat]: CREATE_IN_PROGRESS state changed
2019-10-20 12:07:42Z [ma_pile_donnees.instance_heat]: CREATE_COMPLETE state changed
2019-10-20 12:07:42Z [ma_pile_donnees.association_reverseproxy]: CREATE_IN_PROGRESS state changed
2019-10-20 12:07:47Z [ma_pile_donnees.association_reverseproxy]: CREATE_COMPLETE state changed
2019-10-20 12:07:47Z [ma_pile_donnees]: CREATE_COMPLETE Stack CREATE completed successfully
+---------------------+-------------------------------------------------------------------------------+
| Field | Value |
+---------------------+-------------------------------------------------------------------------------+
| id | 1b8ac52a-51af-43de-b40b-532bd377eda3 |
| stack_name | ma_pile_donnees |
| description | Creation d'un volume systeme a partir d'une image et attachement a l'instance |
| | |
| creation_time | 2019-10-20T12:07:07Z |
| updated_time | None |
| stack_status | CREATE_COMPLETE |
| stack_status_reason | Stack CREATE completed successfully |
+---------------------+-------------------------------------------------------------------------------+

Le paramètre « -c » sur les commandes de type ‘show’ permet de n’afficher que les champs listés :
stack@microwave:~$ openstack stack show ma_pile_donnees -c outputs
+---------+-------------------------------------------------------+
| Field | Value |
+---------+-------------------------------------------------------+
| outputs | - description: Adresse IP publique de l'instance Heat |
| | output_key: instance_heat_public_ip |
| | output_value: 172.24.4.58 |
| | |
+---------+-------------------------------------------------------+
stack@microwave:~$ ssh ubuntu@172.24.4.58
The authenticity of host '172.24.4.58 (172.24.4.58)' can't be established.
ECDSA key fingerprint is SHA256:V+SovoRN1IpMGsXR3UxlaSRxAtsE7uBOUtsCyFuGwYY.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.24.4.58' (ECDSA) to the list of known hosts.
Welcome to Ubuntu 18.04.3 LTS (GNU/Linux 4.15.0-65-generic x86_64)

ubuntu@ma-pile-donnees-instance-heat-c3odmlldiekq:~$ cat /DONNEES/hello.txt


Hello

90 Minutes avec OpenStack – 2019/11/11 62


Créa on d’infrastructures réseau
Nous avons dit que l’infrastructure réseau est cons tuée de :

• réseaux

• sous-réseaux

• routeurs

• ports (qui sont généralement créés de façon implicite, sur les serveurs, les routeurs…)

Ci-dessous une architecture réseau typique d’une applica on ‘Cloud’ avec 4 réseaux :

reverseproxy database

bastion application

public

La pile complète est disponible à ce e adresse :

• h ps://u03.fr/90openstack/4_reseaux.yaml

Il va nous falloir deux adresses IP flo antes (une pour le bas on SSH de votre tenant, et une pour le
reverse-proxy). Nous avons normalement une adresse IP allouée mais elle est déjà associée à un
serveur, nous en allouons deux nouvelles :
stack@microwave:~$ openstack floating ip list -c ID -c 'Floating IP Address' -c 'Fixed IP Address'
+--------------------------------------+---------------------+------------------+
| ID | Floating IP Address | Fixed IP Address |
+--------------------------------------+---------------------+------------------+
| 168bd864-8489-4d50-96dd-24bd93f316e4 | 172.24.4.105 | 10.0.0.43 |
+--------------------------------------+---------------------+------------------+
stack@microwave:~$ openstack floating ip create public -c 'floating_ip_address' -c id
+---------------------+--------------------------------------+
| Field | Value |
+---------------------+--------------------------------------+
| floating_ip_address | 172.24.4.239 |
| id | 3fe5d827-a1aa-47d9-a73f-cb22cdaecc27 |
+---------------------+--------------------------------------+
stack@microwave:~$ openstack floating ip create public -c 'floating_ip_address' -c id
+---------------------+--------------------------------------+
| Field | Value |
+---------------------+--------------------------------------+
| floating_ip_address | 172.24.4.123 |
| id | 311cbd22-c4f4-4190-b342-d0d233906ccc |
+---------------------+--------------------------------------+
stack@microwave:~$ openstack floating ip list -c ID -c 'Floating IP Address' -c 'Fixed IP Address'

90 Minutes avec OpenStack – 2019/11/11 63


+--------------------------------------+---------------------+------------------+
| ID | Floating IP Address | Fixed IP Address |
+--------------------------------------+---------------------+------------------+
| 168bd864-8489-4d50-96dd-24bd93f316e4 | 172.24.4.105 | 10.0.0.43 |
| 311cbd22-c4f4-4190-b342-d0d233906ccc | 172.24.4.123 | None |
| 3fe5d827-a1aa-47d9-a73f-cb22cdaecc27 | 172.24.4.239 | None |
+--------------------------------------+---------------------+------------------+

Nous pouvons désormais instancier notre pile :


stack@microwave:~$ openstack stack create --wait \
--parameter nom_de_cle="LFO" \
--parameter id_floating_ip_bastion="3fe5d827-a1aa-47d9-a73f-cb22cdaecc27" \
--parameter id_floating_ip_reverseproxy="311cbd22-c4f4-4190-b342-d0d233906ccc" \
-t https://u03.fr/90openstack/4_reseaux.yaml \
ma_pile_4_reseaux
2019-10-20 12:46:39Z [ma_pile_4_reseaux]: CREATE_IN_PROGRESS Stack CREATE started
2019-10-20 12:46:40Z [ma_pile_4_reseaux.instance_reverseproxy_security_group]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:41Z [ma_pile_4_reseaux.instance_reverseproxy_security_group]: CREATE_COMPLETE state changed
2019-10-20 12:46:41Z [ma_pile_4_reseaux.reverseproxy_network]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:42Z [ma_pile_4_reseaux.reverseproxy_network]: CREATE_COMPLETE state changed
2019-10-20 12:46:42Z [ma_pile_4_reseaux.router]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:42Z [ma_pile_4_reseaux.reverseproxy_subnet]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:43Z [ma_pile_4_reseaux.instance_bastion_security_group]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:44Z [ma_pile_4_reseaux.instance_database_security_group]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:45Z [ma_pile_4_reseaux.reverseproxy_subnet]: CREATE_COMPLETE state changed
2019-10-20 12:46:45Z [ma_pile_4_reseaux.instance_bastion_volume]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:46Z [ma_pile_4_reseaux.instance_database_security_group]: CREATE_COMPLETE state changed
2019-10-20 12:46:46Z [ma_pile_4_reseaux.instance_application_security_group]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:47Z [ma_pile_4_reseaux.database_network]: CREATE_IN_PROGRESS state changed
2019-10-20 12:46:48Z [ma_pile_4_reseaux.instance_reverseproxy_volume]: CREATE_IN_PROGRESS state changed
…/…
2019-10-20 12:50:02Z [ma_pile_4_reseaux.association_bastion]: CREATE_IN_PROGRESS state changed
2019-10-20 12:50:05Z [ma_pile_4_reseaux.instance_reverseproxy]: CREATE_COMPLETE state changed
2019-10-20 12:50:06Z [ma_pile_4_reseaux.association_reverseproxy]: CREATE_IN_PROGRESS state changed
2019-10-20 12:50:28Z [ma_pile_4_reseaux.association_bastion]: CREATE_COMPLETE state changed
2019-10-20 12:50:42Z [ma_pile_4_reseaux.association_reverseproxy]: CREATE_COMPLETE state changed
2019-10-20 12:50:42Z [ma_pile_4_reseaux]: CREATE_COMPLETE Stack CREATE completed successfully
+---------------------+---------------------------------------------------------------------------+
| Field | Value |
+---------------------+---------------------------------------------------------------------------+
| id | 44cf5b31-f2a5-4e52-9c6e-3d4bc4e765ce |
| stack_name | ma_pile_4_reseaux |
| description | Template HEAT pour obtenir une infra apache + PHP + MariaDB. |
| | Nous construisons 4 instances de serveur: |
| | - Une instance bastion SSH |
…/…
| | En pré-requis vous devez disposer des ID OpenStack des éléments suivants: |
| | - L'adresse IP flottante qui sera attachée au reverse-proxy |
| | - L'adresse IP flottante qui sera attachée au basion SSH |
| | |
| | |
| creation_time | 2019-10-20T12:46:38Z |
| updated_time | None |
| stack_status | CREATE_COMPLETE |
| stack_status_reason | Stack CREATE completed successfully |
+---------------------+---------------------------------------------------------------------------+

A en on même si la pile est finie de créer il peut falloir plusieurs minutes pour que les
différents packages s’installent sur les différentes instances, cela dépend de la puissance de
votre machine DevStack.

A l’issue de la créa on de la pile (et de l’ini alisa on de scripts sur les différents serveurs) si vous
tapez l’adresse IP du reverse-proxy dans votre navigateur web la page suivante, ceci signifie que vous
avez a eint le reverse-proxy, que celui-ci a pu relayer votre requête au serveur d’applica on et que le
serveur d’applica on a interrogé le serveur de bases de données :
stack@microwave:~$ openstack server list -c Name -c Networks
+-------------------+-----------------------------------------------------------------------+
| Name | Networks |
+-------------------+-----------------------------------------------------------------------+
| reverseproxy | reverseproxy=10.99.2.194, 172.24.4.123 |
| bastion | bastion=10.99.1.125, 172.24.4.239 |
| application | application=10.99.3.13 |
| database | database=10.99.4.13 |
| ubuntu-18.04_inst | private=fdac:50a1:b51d:0:f816:3eff:fec8:2ed5, 10.0.0.43, 172.24.4.105 |
+-------------------+-----------------------------------------------------------------------+

90 Minutes avec OpenStack – 2019/11/11 64


Créa on des réseaux et sous-réseaux
Le réseau ‘public’ est celui fourni par le Cloud, nous allons créer les 4 autres, chacun des réseaux est
composé d’au moins un sous-réseau, pour chacun des sous-réseaux il faut choisir les paramètres
suivants :

• Plage d’adresses IP (nota on CIDR)

• Plage d’adresses IP pour a ribuer dynamiquement les adresses IP en DHCP (nota on :


adresses IP début et fin)

• Adresse IP de la passerelle (ce e adresse sera u lisée par le routeur lors de l’a achement du
sous-réseau au routeur)

• Le ou les serveurs DNS qui seront u lisés par les serveurs connectés au sous-réseau

Dans le choix des adresses IP il faut garder à l’esprit qu’il s’agit de réseaux privés propres au
projet, elles ne doivent être uniques qu’à l’intérieur du projet mais il faut éviter qu’elles
entrent en collision avec des réseaux u lisés par les u lisateurs de votre applica on.

Pour chacun des réseaux nous commençons par créer le réseau (objet OS::Neutron::Net) puis
le sous-réseau (OS::Neutron::Subnet).

La liaison entre le sous-réseau et le réseau se fait par la propriété network_id du sous-réseau, en


u lisant get_ressource pour obtenir l’ID du réseau.

La propriété allocation_pools donne la ou les plages d’alloca on par le serveur DHCP, la


propriété cidr donne la plage d’adresses du réseau, gateway_ip est l’adresse IP choisie pour être
celle de la passerelle par défaut du réseau.
bastion_network:
type: OS::Neutron::Net
properties:
name: bastion

bastion_subnet:
type: OS::Neutron::Subnet
properties:
network_id: { get_resource: bastion_network }
allocation_pools:
- {start: 10.99.1.100, end: 10.99.1.250}
cidr: 10.99.1.0/24
dns_nameservers: { get_param: dns }
gatewayCréation du routeur

90 Minutes avec OpenStack – 2019/11/11 65


Nous créons le routeur et nous le ra achons au réseau public (external_gateway_info), ainsi
le routeur routera vers le réseau public tout le trafic qui n’est pas des né à un des réseau qu’il gère, il
fera également de la transla on d’adresse pour masquer les adresses privées mais surtout présenter
une adresse routable sur le réseau public :
router:
type: OS::Neutron::Router
properties:
name: routeur
external_gateway_info:
network: { get_param: public_network }

Nous voyons ci-dessous l’adresse IP publique qui sera u lisée par le routeur pour faire de la
transla on d’adresse (python -m json.tool permet de me re en forme du format JSON) :
stack@microwave:~$ openstack router show routeur -f json -c external_gateway_info | python -m json.tool
{
"external_gateway_info": {
"enable_snat": true,
"external_fixed_ips": [
{
"ip_address": "172.24.4.18",
"subnet_id": "b3ee49a7-80b9-4898-8f53-a58cb1e3908c"
},
{
"ip_address": "2001:db8::2a2",
"subnet_id": "d9a81841-daa0-4f6f-8cde-75de6fb2a343"
}
],
"network_id": "12ceb0b7-9ed6-4bfd-9160-ab44b4f868b2"
}
}

Les interfaces sont créées comme ceci pour connecter les réseaux au routeur : :
router_interface_bastion:
type: OS::Neutron::RouterInterface
properties:
router_id: { get_resource: router }
subnet: { get_resource: bastion_subnet }

Nous voyons ci-dessous les informa ons qui correspondent aux différentes interfaces du réseau une
fois que le pile a été créée, nous retrouvons nos 4 réseaux et les 4 adresses que nous avons a ribué à
chacune des passerelles (python -m json.tool permet de me re en forme du format JSON) :
stack@microwave:~$ openstack router show routeur -f json -c interfaces_info | python -m json.tool
{
"interfaces_info": [
{
"ip_address": "10.99.1.254",
"port_id": "0e31cacf-2fca-4cb8-9feb-19c8cc874eac",
"subnet_id": "9997f78d-f7d5-45ce-b02f-5c42970c988d"
},
{
"ip_address": "10.99.3.254",
"port_id": "85101556-2d35-457e-921b-756ddbc87db1",
"subnet_id": "c5e7e43e-66a3-4f00-a7b2-766496e7dc64"
},
{
"ip_address": "10.99.4.254",
"port_id": "87fe7141-457b-4cf5-aab2-92568f5ab1dc",
"subnet_id": "e9611ee6-abbe-4310-92a2-eb9ccae23951"
},
{
"ip_address": "10.99.2.254",
"port_id": "ad4b5fda-134e-425e-b49e-f3b63ce5098f",
"subnet_id": "bb3f4557-2c9a-467b-b237-3ba6b7458223"
}
]
}

90 Minutes avec OpenStack – 2019/11/11 66


A achement du serveur au réseau
La propriété networks est un tableau de réseaux auxquels doit être a aché le serveur. Il est
possible au passage de fixer l’adresse IP du serveur, si fixed_ip n’est pas spécifié alors une adresse
sera automa quement allouée à par r des plages d’adresses DHCP des sous-réseaux concernés. :
instance_database:
properties:
networks:
- network: { get_resource: database_network }
fixed_ip: 10.99.4.13

Techniquement le serveur est configuré en DHCP, et donc quand une adresse IP est fixée il
s’agit d’une réserva on DHCP effectuée au niveau de Neutron, et non d’une adresse IP
configurée de façon sta que dans les fichiers de configura on de l’interface.

Si vous fixez une adresse IP il vous est conseillé de ne pas le faire dans la plage d’adresse
que vous avez assigné au DHCP lors de la créa on du sous-réseau (allocation_pools).

Lorsque que nous regardons les paramètres réseau d’un de nos serveurs nous retrouvons les
propriétés que nous avons définies pour notre sous-réseau :
ubuntu@bastion:~$ ip addr
[.../…]
2: ens3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc pfifo_fast state UP group default qlen 1000
link/ether fa:16:3e:04:bb:32 brd ff:ff:ff:ff:ff:ff
inet 10.99.1.13/24 brd 10.99.1.255 scope global ens3
valid_lft forever preferred_lft forever
inet6 fe80::f816:3eff:fe04:bb32/64 scope link
valid_lft forever preferred_lft forever

ubuntu@bastion:~$ netstat -rn


Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
0.0.0.0 10.99.1.254 0.0.0.0 UG 0 0 0 ens3
10.99.1.0 0.0.0.0 255.255.255.0 U 0 0 0 ens3

ubuntu@bastion:~$ nslookup u03.fr


Server: 8.8.8.8
Address: 8.8.8.8#53
Non-authoritative answer:
Name: u03.fr
Address: 37.187.126.87

A achement à plusieurs réseaux


Il est possible de spécifier plusieurs réseaux en spécifiant plusieurs entrées network sous la
propriété networks.

C’est par exemple u lisable pour un bas on ou un reverse-proxy afin d’isoler le réseau public et le
réseau privé :

90 Minutes avec OpenStack – 2019/11/11 67


application database

private

bastion reverse-
proxy

public

90 Minutes avec OpenStack – 2019/11/11 68


Le stockage d’objets avec Swi
Swi est un composant de OpenStack qui permet de stocker des objets (fichiers) qui seront
accessibles en HTTP/HTTPS :

• de façon publique sans authen fica on

• à des u lisateurs authen fiés par Keystone et autorisés

• à des u lisateurs disposant d’une URL temporaire donnant des droits spécifiques pour une
période de temps limitée.

Chaque projet peut créer des containers qui vont perme re de stocker des objets, à l’intérieur de
chaque container il n’y a pas de réelle structure arborescente, les objets sont donc tous stockés au
même niveau.

Créa on d’un conteneur Swi et chargement d’objets depuis le Dashboard


Le Dashboard permet de gérer les conteneurs Swi (créa on, chargement de fichiers, destruc on).

En cliquant sur le bouton « +Conteneur » nous affichons l’écran de créa on de conteneur, nous
l’appelons « photos », nous déclarons le conteneur public.

90 Minutes avec OpenStack – 2019/11/11 69


Swi ne gère pas les répertoires mais le Dashboard permet de simuler la créa on d’un répertoire
(bouton « +Dossier »), ceci est simulé en chargeant un fichier à 0 octets avec le nom du pseudo-
dossier.

Il vous est laissé à tre d’exercice à la fin du chapitre la créa on et l’u lisa on de répertoires
depuis le Dashboard.

Le conteneur est en accès public, il se présente sous la forme d’un répertoire accessible en h p, il est
possible d’obtenir l’URL du conteneur en cliquant avec le bouton de droite sur « Lien » en face de
« Accès public » :

Le bouton « » permet de télécharger un fichier dans le conteneur en cours, en cliquant sur


« Parcourir » nous sélec onnons le fichier sur notre poste local, nous rentrons le nom qu’aura le
fichier dans Swi :

Une fois chargé le fichier apparaît dans la liste, il est possible de le télécharger, d’obtenir les
informa ons sur le fichier ou de le supprimer :

90 Minutes avec OpenStack – 2019/11/11 70


Le lien obtenu pour le conteneur est:
• http://192.168.1.211:8080/v1/AUTH_3f36cd33d14e468293caa7bf311c00de/photos

Le nom du fichier donné lors du chargement est ‘lumieres’, l‘URL du fichier est donc :
• http://192.168.1.211:8080/v1/AUTH_3f36cd33d14e468293caa7bf311c00de/photos/lumieres

Manipula on des conteneurs et objets en ligne de commande


Il est possible de lister les conteneurs et leur contenu à l’aide de l’u litaire en ligne de commande :
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack container list
+--------+
| Name |
+--------+
| photos |
+--------+
stack@microwave:~$ openstack container show photos
+--------------+---------------------------------------+
| Field | Value |
+--------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| bytes_used | 5249087 |
| container | photos |
| object_count | 1 |
| read_acl | .r:*,.rlistings |
+--------------+---------------------------------------+

90 Minutes avec OpenStack – 2019/11/11 71


Il est également possible de lister le contenu des conteneurs ainsi que les informa ons sur un objet à
l’aide de l’u litaire en ligne de commande :
stack@microwave:~$ openstack object list photos
+----------+
| Name |
+----------+
| lumieres |
+----------+
stack@microwave:~$ openstack object show photos lumieres
+----------------+---------------------------------------+
| Field | Value |
+----------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 5249087 |
| content-type | application/octet-stream |
| etag | f66ca1814ff66b249ee973b01139207e |
| last-modified | Wed, 07 Mar 2018 21:10:44 GMT |
| object | lumieres |
| properties | Orig-Filename='20140717_210108.JPG' |
+----------------+---------------------------------------+

Stockage et récupéra on d’un fichier


La commande « openstack object create » permet charger un objet dans Swi , on note que
le champ « etag » est en fait le hash md5 du fichier :
stack@microwave:~$ openstack object create --name takeshiba.jpg photos /tmp/IMG_20140718_015943.jpg
+---------------+-----------+----------------------------------+
| object | container | etag |
+---------------+-----------+----------------------------------+
| takeshiba.jpg | photos | 584175f6b846a13f34477d08d1ed9a0c |
+---------------+-----------+----------------------------------+
stack@microwave:~$ openstack object show photos takeshiba.jpg
+----------------+---------------------------------------+
| Field | Value |
+----------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 2357220 |
| content-type | image/jpeg |
| etag | 584175f6b846a13f34477d08d1ed9a0c |
| last-modified | Sat, 10 Mar 2018 21:27:25 GMT |
| object | takeshiba.jpg |
+----------------+---------------------------------------+
stack@microwave:~$ md5sum /tmp/IMG_20140718_015943.jpg
584175f6b846a13f34477d08d1ed9a0c /tmp/IMG_20140718_015943.jpg

La commande « openstack object save» permet télécharger un objet présent dans Swi , on
note que par défaut la commande sauve l’objet avec le nom sous lequel il a été stocké dans Swi , il
est possible d’u liser le paramètre « --file » pour spécifier le nom (et le chemin) du fichier sous
lequel l’objet doit être sauvegardé localement :
stack@microwave:~$ openstack object save photos lumieres
stack@microwave:~$ file lumieres
lumieres: JPEG image data, Exif standard: [TIFF image data, little-endian, direntries=12, height=3456, manufacturer=SAMSUNG,
model=EK-GC100, orientation=upper-left, xresolution=208, yresolution=216, resolutionunit=2, software=GC100XXBMC4,
datetime=2014:07:17 21:01:07, width=4608], baseline, precision 8, 4608x3456, frames 3
stack@microwave:~$ openstack object save photos lumieres --file /tmp/lumieres.jpg
stack@microwave:~$ ls -l /tmp/lumieres.jpg
-rw-rw-r-- 1 stack stack 5249087 Mar 10 22:36 /tmp/lumieres.jpg

Ajout de propriétés
Lors de l’ajout de l’objet via le Dashboard une propriété avait été ajoutée automa quement (le nom
réel du fichier ini al), ce que n’a pas fait la commande « openstack object create » :
stack@microwave:~$ openstack object show photos lumieres
+----------------+---------------------------------------+
| Field | Value |
+----------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 5249087 |
| content-type | application/octet-stream |

90 Minutes avec OpenStack – 2019/11/11 72


| etag | f66ca1814ff66b249ee973b01139207e |
| last-modified | Wed, 07 Mar 2018 21:10:44 GMT |
| object | lumieres |
| properties | Orig-Filename='20140717_210108.JPG' |
+----------------+---------------------------------------+
stack@microwave:~$ openstack object show photos takeshiba.jpg
+----------------+---------------------------------------+
| Field | Value |
+----------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 2357220 |
| content-type | image/jpeg |
| etag | 584175f6b846a13f34477d08d1ed9a0c |
| last-modified | Sat, 10 Mar 2018 21:27:25 GMT |
| object | takeshiba.jpg |
+----------------+---------------------------------------+

Il est possible d’ajouter les propriétés de son choix à un objet sous la forme de paires
« clé=valeur » :
stack@microwave:~$ openstack object set photos takeshiba.jpg --property annee=2014 \
--property categorie=vacances \
--property lieu='Tokyo'
stack@microwave:~$ openstack object show photos takeshiba.jpg
+----------------+--------------------------------------------------+
| Field | Value |
+----------------+--------------------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 2357220 |
| content-type | image/jpeg |
| etag | 584175f6b846a13f34477d08d1ed9a0c |
| last-modified | Sat, 10 Mar 2018 21:55:17 GMT |
| object | takeshiba.jpg |
| properties | Annee='2014', Categorie='vacances', Lieu='Tokyo' |
+----------------+--------------------------------------------------+

La commande « set » efface les propriétés déjà présentes sur un objet, supposons que
nous désirions modifier la propriété ‘annee’ pour me re ‘2015’, il ne suffit pas de
spécifier la propriété ‘annee’, sinon toutes les autres propriétés seront supprimées.

stack@microwave:~$ openstack object set photos takeshiba.jpg --property annee=2015


stack@microwave:~$ openstack object show photos takeshiba.jpg
+----------------+---------------------------------------+
| Field | Value |
+----------------+---------------------------------------+
| account | AUTH_3f36cd33d14e468293caa7bf311c00de |
| container | photos |
| content-length | 2357220 |
| content-type | image/jpeg |
| etag | 584175f6b846a13f34477d08d1ed9a0c |
| last-modified | Sat, 10 Mar 2018 21:56:52 GMT |
| object | takeshiba.jpg |
| properties | Annee='2015' |
+----------------+---------------------------------------+

La commande « unset » permet d’effacer une ou plusieurs propriétés, il vous est laissé à
tre d’exercice l’ajout et la suppression de propriétés sur un objet présent dans Swi .

90 Minutes avec OpenStack – 2019/11/11 73


Terraform
On l’a vu, les API OpenStack sont très puissantes, elles sont u lisables dans la plupart des langages de
programma on et donc de nombreux logiciels ont été développés pour rer par e de OpenStack et
de ses API.

Terraform permet de faire de l’orchestra on comme Heat, il permet d’u liser de nombreuses
solu ons de Cloud, dont OpenStack :

• h ps://www.terraform.io/docs/providers/openstack/

Même si le format des fichiers est différent entre Heat et Terraform la logique est la même, en effet
Heat et Terraform sont tributaires des API OpenStack et de la façon dont elles s’ar culent.

Les descrip ons d’infrastructures dans Terraform s’appellent ‘configura ons’.

Appliquer la configura on (terraform apply) va effectuer les ac ons nécessaires pour réaliser
l’infrastructure décrite dans la configura on, soit en la construisant (lors du premier appel à
terraform apply), soit en me ant à jour l’infrastructure (lors appels suivants à terraform
apply). Pour ceci Terraform va bâ r un ‘plan’ des opéra ons à réaliser.

Un appel à terraform destroy va perme re de détruire l’infrastructure construite.

Installa on et ini alisa on


Terraform est téléchargeable à ce e adresse : h ps://www.terraform.io/downloads.html

Terraform est disponible pour Windows et Linux (‘i386’, ‘amd64’ et processeurs ‘arm’). Il se présente
sous la forme d’un fichier ‘.zip’ contenant un unique programme exécutable en commande ligne.

Les processeurs ‘arm’ sont u lisés sur la plupart des téléphones portables, des table es, de
certains équipements réseaux et ordinateurs ‘monocarte’ tels que les Raspberry Pi

Dans ce e exemple nous u lisons un Raspberry Pi (qui fait par e de mes machines de
tests), il s’agit d’une mini machine qui coûte environ 40 euros.

h ps://blog.u03.fr/la-paillasse-de-linforma cien/

Téléchargez la version qui correspond à votre plateforme, dézippez le fichier et placez-le dans un
répertoire vide que vous appelez ‘tf’ (par exemple).
foucher@raspberrypi:~/tf $ wget https://releases.hashicorp.com/terraform/0.12.12/terraform_0.12.12_linux_arm.zip
--2019-10-20 14:36:39-- https://releases.hashicorp.com/terraform/0.12.12/terraform_0.12.12_linux_arm.zip
Resolving releases.hashicorp.com (releases.hashicorp.com)... 151.101.1.183, 151.101.65.183, 151.101.129.183, ...
Connecting to releases.hashicorp.com (releases.hashicorp.com)|151.101.1.183|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 15115877 (14M) [application/zip]
Saving to: ‘terraform_0.12.12_linux_arm.zip’

terraform_0.12.12_linux_arm.zip 100%
[====================================================================================>] 14.42M 790KB/s in 19s

2019-10-20 14:36:59 (785 KB/s) - ‘terraform_0.12.12_linux_arm.zip’ saved [15115877/15115877]

foucher@raspberrypi:~/tf $ unzip terraform_0.12.12_linux_arm.zip


Archive: terraform_0.12.12_linux_arm.zip

90 Minutes avec OpenStack – 2019/11/11 74


inflating: terraform

Dans le répertoire ‘tf’ créez un fichier que vous appellerez ‘provider.tf’ (par exemple, mais le
nom doit finir par ‘.tf’) :
provider "openstack" {
user_name = "demo"
tenant_name = "demo"
password = "topsecret"
auth_url = "http://192.168.1.211/identity"
region = "RegionOne"
}

Lancez la commande ‘terraform init’, Terraform va charger tous les fichiers ‘.tf’ présents
dans le répertoire (ici uniquement le fichier ‘provider.tf’) et il va télécharger depuis le site de
l’éditeur le plugin nécessaire pour u liser OpenStack :
foucher@raspberrypi:~/tf $ ./terraform init

Initializing the backend...

Initializing provider plugins...


- Checking for available provider plugins...
- Downloading plugin for provider "openstack" (terraform-providers/openstack) 1.23.0...

The following providers do not have any version constraints in configuration,


so the latest version was installed.

To prevent automatic upgrades to new major versions that may contain breaking
changes, it is recommended to add version = "..." constraints to the
corresponding provider blocks in configuration, with the constraint strings
suggested below.

* provider.openstack: version = "~> 1.23"

Terraform has been successfully initialized!

You may now begin working with Terraform. Try running "terraform plan" to see
any changes that are required for your infrastructure. All Terraform commands
should now work.

If you ever set or change modules or backend configuration for Terraform,


rerun this command to reinitialize your working directory. If you forget, other
commands will detect it and remind you to do so if necessary.

Éléments d’une configura on


Nous avons déjà vu le provider, il permet à Terraform de récupérer le bon plugin et permet de lui
fournir les paramètres associés (les mêmes que dans les variables d’environnement posi onnées par
le script openrc).

Terraform est mul -provider, il permet par exemple de déployer à la fois de l’OpenStack, de
l’AWS et du VMware…

Dans Terraform les variables (variable) sont l’équivalent des paramètres dans Heat, elle
perme ent d’adapter la configura on à l’environnement dans lequel elle est déployée.

Les ressources (resource) sont les éléments de l’infrastructure, comme dans Heat.

Les sources de données (data) sont des construc ons syntaxiques qui perme ent de récupérer l’ID
unique d’éléments préexistants dans OpenStack à par r de différents paramètres (par exemple
récupérer l’ID d’une image pour construire un volume de boot...)

90 Minutes avec OpenStack – 2019/11/11 75


Une première configura on
Nous allons faire une première configura on qui classiquement va créer une instance à par r d’une
image.

Nous créons un fichier que nous appelons premiere_configuration.tf qui est également
disponible à l’adresse h ps://u03.fr/90openstack/premiere_configura on. :
variable "nom_de_cle" {
description = "Nom de la clé publique SSH permettant d'accéder aux serveurs"
}

variable "gabarit_instance" {
description = "Gabarit qui sera utilisé par l'instance"
default = "ds1G"
}

variable "image_instance" {
description = "Nom de l'image"
default = "ubuntu-18.04"
}

variable "reseau_prive" {
description = "Nom du reseau prive"
default = "private"
}

resource "openstack_compute_instance_v2" "instance_terraform" {


name = "instance_terraform"
flavor_name = "${var.gabarit_instance}"
key_pair = "${var.nom_de_cle}"
image_name = "${var.image_instance}"
network {
name = "${var.reseau_prive}"
}
}

Vous avons 4 éléments variable qui correspondent à nos paramètres, il y a une descrip on et il
est possible de me re une valeur par défaut.

La valeur des paramètres est récupérée par la construc on syntaxique suivante :

• "${var.image_instance}"

Comme dans Heat il est possible de passer un fichier avec la valeur des paramètres. Nous créons le
fichier terraform.tfvars avec la valeur de nos éléments variable (nous conservons la valeur
par défaut pour les variables reseau_prive et image_instance) :
nom_de_cle = "LFO"
gabarit_instance = "ds1G"

La commande terraform plan nous permet de visualiser les opéra ons nécessaires à la
construc on de l’infrastructure décrite dans la configura on :
foucher@raspberrypi:~/tf $ ./terraform plan
The refreshed state will be used to calculate this plan, but will not be
persisted to local or remote state storage.
------------------------------------------------------------------------
An execution plan has been generated and is shown below.
Resource actions are indicated with the following symbols:
+ create

Terraform will perform the following actions:

# openstack_compute_instance_v2.instance_terraform will be created


+ resource "openstack_compute_instance_v2" "instance_terraform" {
+ access_ip_v4 = (known after apply)
+ access_ip_v6 = (known after apply)
+ all_metadata = (known after apply)
+ availability_zone = (known after apply)
+ flavor_id = (known after apply)
+ flavor_name = "ds1G"
+ force_delete = false
+ id = (known after apply)

90 Minutes avec OpenStack – 2019/11/11 76


+ image_id = (known after apply)
+ image_name = "ubuntu-18.04"
+ key_pair = "LFO"
+ name = "instance_terraform"
+ power_state = "active"
+ region = (known after apply)
+ security_groups = (known after apply)
+ stop_before_destroy = false

+ network {
+ access_network = false
+ fixed_ip_v4 = (known after apply)
+ fixed_ip_v6 = (known after apply)
+ floating_ip = (known after apply)
+ mac = (known after apply)
+ name = "private"
+ port = (known after apply)
+ uuid = (known after apply)
}
}

Plan: 1 to add, 0 to change, 0 to destroy.

------------------------------------------------------------------------

Note: You didn't specify an "-out" parameter to save this plan, so Terraform
can't guarantee that exactly these actions will be performed if
"terraform apply" is subsequently run.

La commande terraform apply va déployer la configura on, une confirma on est demandée :
foucher@raspberrypi:~/tf $ ./terraform apply

An execution plan has been generated and is shown below.

[…/…] Rappel du plan

Do you want to perform these actions?


Terraform will perform the actions described above.
Only 'yes' will be accepted to approve.

Enter a value: yes

openstack_compute_instance_v2.instance_terraform: Creating...
openstack_compute_instance_v2.instance_terraform: Still creating... [10s elapsed]
openstack_compute_instance_v2.instance_terraform: Creation complete after 19s [id=c8e4a067-d449-42ba-b5cf-ada95f2ff248]

Apply complete! Resources: 1 added, 0 changed, 0 destroyed.

Nous retrouvons notre serveur en u lisant la commande CLI openstack :


stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ openstack server show instance_terraform
stack@microwave:~$ openstack server show instance_terraform
+-----------------------------+----------------------------------------------------------+
| Field | Value |
+-----------------------------+----------------------------------------------------------+
| OS-DCF:diskConfig | MANUAL |
| OS-EXT-AZ:availability_zone | nova |
| OS-EXT-STS:power_state | Running |
| OS-EXT-STS:task_state | None |
| OS-EXT-STS:vm_state | active |
| OS-SRV-USG:launched_at | 2019-10-20T15:58:54.000000 |
| OS-SRV-USG:terminated_at | None |
| accessIPv4 | |
| accessIPv6 | |
| addresses | private=fdac:50a1:b51d:0:f816:3eff:fe23:e552, 10.0.0.24 |
| config_drive | |
| created | 2019-10-20T15:58:42Z |
| flavor | ds1G (d2) |
| hostId | b3ce8aa16af22651ac4ab1291280fd727ff9c016c9068dcfcc861a75 |
| id | c8e4a067-d449-42ba-b5cf-ada95f2ff248 |
| image | ubuntu-18.04 (7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5) |
| key_name | LFO |
| name | instance_terraform |
| progress | 0 |
| project_id | 5cd4212611654857a9e941a7b5d35e13 |
| properties | |
| security_groups | name='default' |
| status | ACTIVE |
| updated | 2019-10-20T15:58:55Z |
| user_id | 57d02b0938d149a1aac96ce6757a3a14 |
| volumes_attached | |
+-----------------------------+----------------------------------------------------------+

La commande terraform destroy va perme re de détruire l’infrastructure :

90 Minutes avec OpenStack – 2019/11/11 77


foucher@raspberrypi:~/tf $ ./terraform destroy
openstack_compute_instance_v2.instance_terraform: Refreshing state... [id=c8e4a067-d449-42ba-b5cf-ada95f2ff248]

An execution plan has been generated and is shown below.


Resource actions are indicated with the following symbols:
- destroy

Terraform will perform the following actions:

# openstack_compute_instance_v2.instance_terraform will be destroyed


- resource "openstack_compute_instance_v2" "instance_terraform" {
- access_ip_v4 = "10.0.0.24" -> null
- access_ip_v6 = "[fdac:50a1:b51d:0:f816:3eff:fe23:e552]" -> null
- all_metadata = {} -> null
- availability_zone = "nova" -> null
- flavor_id = "d2" -> null
- flavor_name = "ds1G" -> null
- force_delete = false -> null
- id = "c8e4a067-d449-42ba-b5cf-ada95f2ff248" -> null
- image_id = "7ab813dd-6937-4f96-8cd1-ed0ec64e8ad5" -> null
- image_name = "ubuntu-18.04" -> null
- key_pair = "LFO" -> null
- name = "instance_terraform" -> null
- power_state = "active" -> null
- region = "RegionOne" -> null
- security_groups = [
- "default",
] -> null
- stop_before_destroy = false -> null

- network {
- access_network = false -> null
- fixed_ip_v4 = "10.0.0.24" -> null
- fixed_ip_v6 = "[fdac:50a1:b51d:0:f816:3eff:fe23:e552]" -> null
- mac = "fa:16:3e:23:e5:52" -> null
- name = "private" -> null
- uuid = "0e6e2f0c-c4cc-4eca-8428-8117864b6e4a" -> null
}
}

Plan: 0 to add, 0 to change, 1 to destroy.

Do you really want to destroy all resources?


Terraform will destroy all your managed infrastructure, as shown above.
There is no undo. Only 'yes' will be accepted to confirm.

Enter a value: yes

openstack_compute_instance_v2.instance_terraform: Destroying... [id=c8e4a067-d449-42ba-b5cf-ada95f2ff248]


openstack_compute_instance_v2.instance_terraform: Still destroying... [id=c8e4a067-d449-42ba-b5cf-ada95f2ff248, 10s elapsed]
openstack_compute_instance_v2.instance_terraform: Destruction complete after 10s

Destroy complete! Resources: 1 destroyed.

Créa on d’un volume système et d’un groupe de sécurité :


Nous allons déployer une infrastructure qui comprend les éléments suivants :

• Un volume de boot créé à par r d’une image

• Une instance qui démarre sur ce volume en u lisant un script de démarrage (user_data)

• Un groupe de sécurité autorisant le trafic SSH

Dans les piles Heat il est possible de créer un volume de boot à par r du nom de l’image ou de son ID
unique. L’unicité des noms d’images n’est pas garan e par Glance et lorsque deux images portent le
même nom cela provoque l’échec de créa on de la pile Heat.

Afin de se prémunir contre ce genre d’échecs Terraform u lise l’ID de l’image au lieu de son nom, une
source de donnés (data) permet d’interroger la catalogue Glance pour récupérer l’ID à par r du
nom de l’image passé dans une variable.
variable "image_instance" {
description = "Nom de l'image"
default = "ubuntu-18.04"
}

data "openstack_images_image_v2" "image_boot" {

90 Minutes avec OpenStack – 2019/11/11 78


name = "${var.image_instance}"
most_recent = true
}

Il est ensuite possible de créer le volume à par r de ce e image.

Le volume_type est également récupéré à par r d’une variable (il s’agit habituellement de
lvmdriver-1 pour DevStack).

L’ID de l’image est récupéré à par r de la source de données grâce à la construc on suivante :
• "${data.openstack_images_image_v2.image_boot.id}"
resource "openstack_blockstorage_volume_v2" "volume_boot_terraform" {
name = "volume_terraform"
description = "Le volume de boot"
size = 10
volume_type = "${var.type_volume}"
image_id = "${data.openstack_images_image_v2.image_boot.id}"
}

Il faut créer le groupe de sécurité puis lui a acher les règles de sécurité, ici celle qui autorise le trafic
SSH (tcp port 22) :
resource "openstack_networking_secgroup_v2" "secgroup_tf" {
name = "secgroup_ssh"
description = "Autoriser le flux SSH"
}

resource "openstack_networking_secgroup_rule_v2" "secgrouprule_secgroup_tf_ssh" {


direction = "ingress"
ethertype = "IPv4"
protocol = "tcp"
port_range_min = 22
port_range_max = 22
remote_ip_prefix = "0.0.0.0/0"
security_group_id = "${openstack_networking_secgroup_v2.secgroup_tf.id}"
}

Nous pouvons désormais créer notre serveur en y a achant les différents éléments que nous avons
construits. Le script exécuté au moment du lancement du serveur (user_data) est recopié depuis
un fichier, contrairement aux piles Heat dans lesquelles il est inclus dans le fichier de la pile :
resource "openstack_compute_instance_v2" "instance_terraform" {
name = "instance_terraform"
flavor_name = "${var.gabarit_instance}"
key_pair = "${var.nom_de_cle}"
security_groups = ["${openstack_networking_secgroup_v2.secgroup_tf.name}"]
user_data = "${file("configuration_evoluee_user_data.sh")}"

block_device {
uuid = "${openstack_blockstorage_volume_v2.volume_boot_terraform.id}"
source_type = "volume"
destination_type = "volume"
boot_index = 0
delete_on_termination = false
}
}

Le fichier configuration_evoluee_user_data.sh provient d’une de nos piles Heat


précédentes :
#!/bin/bash -v

apt-get update
apt-get install -y cowsay fortune
/usr/games/fortune | /usr/games/cowsay
/usr/games/fortune | /usr/games/cowsay > /dev/tty1
cat << EOF >> /home/ubuntu/.bashrc
/usr/games/fortune | /usr/games/cowsay
EOF

Les fichiers pour ce e configura on sont disponibles à ce e adresse :

90 Minutes avec OpenStack – 2019/11/11 79


• h ps://u03.fr/90openstack/configura on_evoluee.

• h ps://u03.fr/90openstack/configura on_evoluee_user_data.sh

Le fichier terraform.tfvars avec la valeur de nos éléments variable con endra :


nom_de_cle = "LFO"
gabarit_instance = "ds1G"
reseau_public = "public"
type_volume = "lvmdriver-1"

Vous devez effacer le fichier premiere_configura on. , sinon Terraform va également tenter
de déployer le serveur décrit dedans.

Il vous est laissé à tre d’exercice d’afficher le plan, de déployer la configura on, de vous
connecter à l’instance avec l’u lisateur ubuntu (vous serez également accueilli par la vache)
puis de détruire la configura on.

Note : N’oubliez pas qu’il faut un peu de temps au serveur pour se lancer et exécuter son
script de démarrage.

Créa on et u lisa on de réseaux


Tout comme avec Heat on commence par créer un réseau, puis on y a ache un ou plusieurs sous-
réseaux.

Nous voyons dans l’exemple ci-dessous que le DNS est une variable, il est en effet important que le
DNS soit adapté à notre infrastructure, sinon de nombreuses fonc onnalités risquent de ne pas
fonc onner dans les instances a achées au réseau.

Les différents paramètres sont les mêmes que pour Heat, en par culier les plages d’adresses IP
dynamiques pour DHCP (allocation_pools) :
variable "dns" {
type = "list"
description = "Adresse IP du serveur DNS"
}

resource "openstack_networking_network_v2" "net_bastion" {


name = "net_bastion"
admin_state_up = "true"
}

resource "openstack_networking_subnet_v2" "subnet_bastion" {


name = "subnet_bastion"
network_id = "${openstack_networking_network_v2.net_bastion.id}"
cidr = "10.99.1.0/24"
allocation_pools = {
start = "10.99.1.100"
end = "10.99.1.250"
} dns_nameservers = "${var.dns}"
gateway_ip = "10.99.1.254"
ip_version = 4
}

La variable DNS est une liste de serveurs DNS.

Il est nécessaire de spécifier type = "list" dans la déclara on de la variable.

90 Minutes avec OpenStack – 2019/11/11 80


Dans le fichier .tfvars la valeur de la varible se défini comme ceci :

dns = ["8.8.8.8", "8.8.4.4"]

Une fois les différents réseaux définis il est possible de créer le routeur pour les relier entre eux et les
relier au réseau public. Là encore, le nom du réseau public doit correspondre à l’infrastructure et il
s’agit donc d’une variable pour rendre notre configura on Terraform partageable.

resource "openstack_networking_router_v2" "routeur" {


name = "routeur"
admin_state_up = true
external_network_id = "${var.id_reseau_public}"
}

resource "openstack_networking_router_interface_v2" "router_interface_bastion" {


router_id = "${openstack_networking_router_v2.routeur.id}"
subnet_id = "${openstack_networking_subnet_v2.subnet_bastion.id}"
}

resource "openstack_networking_router_interface_v2" "router_interface_pio" {


router_id = "${openstack_networking_router_v2.routeur.id}"
subnet_id = "${openstack_networking_subnet_v2.subnet_pio.id}"
}

Notez comment le serveur est ra aché à son réseau, ici une adresse fixe lui est donnée :
resource "openstack_compute_instance_v2" "instance_bastion" {
[.../...]
network {
fixed_ip_v4 = "${var.ip_interne_bastion}"
name = "net_bastion"
access_network = true
}
[.../...]
}

Script d’ini alisa on d’instance simple


Terraform dispose de la possibilité de faire exécuter un script au moment du lancement de l’instance
(ce qui est normal, les user_data étant une fonc onnalité de OpenStack).

Le cas le plus simple est l’inclusion d’un fichier externe qui sera exécuté au lancement de l’instance :
resource "openstack_compute_instance_v2" "instance_terraform" {
name = "instance_terraform"
flavor_name = "${var.gabarit_instance}"
key_pair = "${var.nom_de_cle}"
security_groups = ["${openstack_networking_secgroup_v2.secgroup_tf.name}"]
user_data = "${file("cowsay.sh")}"

block_device {
uuid = "${openstack_blockstorage_volume_v2.volume_boot_terraform.id}"
source_type = "volume"
destination_type = "volume"
boot_index = 0
delete_on_termination = false
}
}

Le fichier cowsay.sh est un script shell classique :


#!/bin/bash -v

apt-get update
apt-get install -y cowsay fortune
/usr/games/fortune | /usr/games/cowsay
cat << EOF >> /home/ubuntu/.bashrc
/usr/games/fortune | /usr/games/cowsay
EOF

90 Minutes avec OpenStack – 2019/11/11 81


Script d’ini alisa on d’instance complexe (template)
Terraform dispose d’un système de templates qui permet, entre autres, de personnaliser le script
d’ini alisa on des instances en remplaçant des mo fs dans un fichier modèle

Un élément ‘data template_file’ est u lisé pour désigner le fichier modèle et faire la liaison entre les
mo fs et leurs valeurs de remplacement.
data "template_file" "userdata_bastion" {
template = "${file("bastion.tpl")}"
vars {
ip_docker = "${var.ip_interne_docker}"
ip_pio = "${var.ip_interne_pio}"
}
}

Voici un exemple de fichier template ‘bastion.tpl’ et de fichier résultant :


#!/bin/bash #!/bin/bash

tee -a /etc/hosts << EOF tee -a /etc/hosts << EOF

${ip_docker} docker 10.10.10.1 docker


${ip_pio} pio reverseproxy 10.12.12.1 pio reverseproxy
EOF EOF

La liaison avec l’instance se fait comme ceci :


resource "openstack_compute_instance_v2" "instance_bastion" {
name = "bastion"
flavor_name = "${var.gabarit_instance_bastion}"
user_data = "${data.template_file.userdata_bastion.rendered}"
network {
[.../...]
}

90 Minutes avec OpenStack – 2019/11/11 82


U lisa on directe des API
Jusqu’ici nous avons u lisé les API de OpenStack à travers l’interface en commande de ligne, le
Dashboard ou un programme externe comme Terraform

La puissance de OpenStack est l’ouverture des API.

Les API u lisent le protocole HTTPS (ou HTTP pour DevStack), le formalisme JSON en entrée et en
sor e.

Les opéra ons offertes par l’API sont de type CRUD (Create, Read, Update, Delete), les verbes HTTP
u lisés sont les suivants :

• Create : POST

• Read : GET

• Update : PUT

• Detele : DELETE

Les paramètres sont passés soit dans l’URL (path) soit dans le corps de la requête (body) au format
JSON.

Obten on d’un Token et de la liste des endpoints


Nous l’avons dit, KeyStone est la pierre angulaire du système, il permet l’authen fica on et con ent
la base de données des u lisateurs, des projets et les points d’entrée pour les autres API.

La première chose à faire pour u liser les API est de s’authen fier auprès de KeyStone, en retour on
ob ent un token, on peut aussi obtenir les points d’entrée pour contacter les autres API. On u lise
ensuite ce token pour prouver notre iden té aux autres API (a en on le token obtenu a une durée
de validité).

Le détail de l’API KeyStone pour l’authen fica on sur un domaine est disponible à l’adresse suivante :
• h ps://developer.openstack.org/api-ref/iden ty/v3/#token-authen ca on-with-scoped-authoriza on

Nous u lisons curl pour dialoguer avec l’API de KeyStone, le protocole est HTTP, nous envoyons
l’entête ‘Content-Type’ pour informer l’API que le format des données envoyées est JSON, les
données à envoyer sont passées après le paramètre ‘data’ (et donc la méthode HTTP sera POST),
nous u lisons les variables d’environnement valorisées par le script openrc
stack@microwave:~$ source devstack/openrc demo demo
stack@microwave:~$ curl --silent \
--request POST \
--include \
--header "Content-Type: application/json" \
--data '
{
"auth": {
"identity": {
"methods": [ "password" ],
"password": { "user": { "domain": { "id": "'$OS_PROJECT_DOMAIN_ID'" },
"name": "'$OS_USERNAME'",
"password": "'$OS_PASSWORD'" } }
},
"scope": {
"project": { "name": "'$OS_PROJECT_NAME'", "domain": { "id": "'$OS_PROJECT_DOMAIN_ID'" } }
}
}

90 Minutes avec OpenStack – 2019/11/11 83


}
' \
"$OS_AUTH_URL/v$OS_IDENTITY_API_VERSION/auth/tokens"; echo

La réponse est en deux par es :

• les entêtes HTTP qui vont contenir le code retour (ici ‘201 Created’ qui signifie qu’un
token a été créé), ainsi que le token après l’entête ‘X-Subject-Token’

• les données qui con ennent la date d’expira on du token ainsi que les différents points
d’entrée des autres API :
HTTP/1.1 201 Created
Date: Wed, 14 Mar 2018 21:07:53 GMT
Server: Apache/2.4.18 (Ubuntu)
X-Subject-Token:
gAAAAABarDI1U6c4sJJW8WRYQ4jJ1IYxNom8ee8wrzaVgHlQOChh0ZrpNA0VwIK6ObZ3eP0F20vkACAjAFpxurl5p6N3XYdDKtkICE5qE20aLFCAHseYtFpwqAQom
QGMfXV73cpckXUz1GUfAKKtPmrykqKHBezi8iFTHZicYkp4dq4_JZj9XDQ
Vary: X-Auth-Token
Content-Type: application/json
Content-Length: 5150
x-openstack-request-id: req-67b012fd-8a25-4a42-a034-d5640f48c209
Connection: close

{"token": {"is_domain": false, "methods": ["password"], "roles": [{"id": "c4f81ba8d77b49d3a3d55712dcf42b11", "name":


"Member"}, {"id": "e1d0b86682854ef1b56878f07775b3e4", "name": "anotherrole"}], "expires_at": "2018-03-14T22:07:53.000000Z",
"project": {"domain": {"id": "default", "name": "Default"}, "id": "3f36cd33d14e468293caa7bf311c00de", "name": "demo"},
"catalog": [{"endpoints": [{"region_id": "RegionOne", "url":
"http://192.168.1.211/heat-api/v1/3f36cd33d14e468293caa7bf311c00de", "region": "RegionOne", "interface": "public", "id":
"9ecdad764d374f54bff9faed8fc395d9"}, {"region_id": "RegionOne", "url": "http://192.168.1.211/heat-
[…/…]
"nova"}], "user": {"password_expires_at": null, "domain": {"id": "default", "name": "Default"}, "id":
"cf025806abdb476f936a72573a8ae66f", "name": "demo"}, "audit_ids": ["tH_IWiaRTh6z5WPRB9R8Fw"], "issued_at": "2018-03-
14T21:07:53.000000Z"}}

La par e JSON n’est pas très lisible par un être humain, il est possible de le rendre lisible
humainement, nous devons supprimer l’affichage des entêtes pour ceci (et donc le token ne sera pas
visible).

Nous voyons au passage le endpoint du service ‘cinderv3’ (‘volumev3’) qui gère les volumes,
celui de ‘neutron’ qui gère le réseau (‘network’) et du service ‘nova’ (‘compute’) qui gère les
instances:
stack@microwave:~$ curl --silent \
--request POST \
--header "Content-Type: application/json" \
--data '
{
"auth": {
"identity": {
"methods": [ "password" ],
"password": { "user": { "domain": { "id": "'$OS_PROJECT_DOMAIN_ID'" },
"name": "'$OS_USERNAME'",
"password": "'$OS_PASSWORD'" } }
},
"scope": {
"project": { "name": "'$OS_PROJECT_NAME'", "domain": { "id": "'$OS_PROJECT_DOMAIN_ID'" } }
}
}
}
' "$OS_AUTH_URL/v$OS_IDENTITY_API_VERSION/auth/tokens" | python -m json.tool | pygmentize -l json

{
"token": {
"audit_ids": [
"lg6y1QFKT0Czcy26OlwjKA"
],
"catalog": [
{
[…/…)
{
"endpoints": [
{
"id": "17069516fedb40cc8e44f15ea4b02dba",
"interface": "public",
"region": "RegionOne",
"region_id": "RegionOne",

90 Minutes avec OpenStack – 2019/11/11 84


"url": "http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de"
}
],
"id": "9e2e4494f10a45b8b2f5000874c1822e",
"name": "cinderv3",
"type": "volumev3"
},
[…/…]
{
"endpoints": [
{
"id": "57953f4651274b2da61f32c0757a7697",
"interface": "public",
"region": "RegionOne",
"region_id": "RegionOne",
"url": "http://192.168.1.211:9696/"
}
],
"id": "77e4245aa4e84492901cc89c7280e99c",
"name": "neutron",
"type": "network"
},
[…/…]
{
"endpoints": [
{
"id": "c813bc135d5143a0b7327960ab3d92a7",
"interface": "public",
"region": "RegionOne",
"region_id": "RegionOne",
"url": "http://192.168.1.211/compute/v2.1"
}
],
"id": "fb15a47673b74f64b16e57b97aae0c8d",
"name": "nova",
"type": "compute"
}
[…/…]
"expires_at": "2018-03-17T22:19:27.000000Z",
"is_domain": false,
"issued_at": "2018-03-17T21:19:27.000000Z",
[…/…]
}

L’URL du endpoint de Cinder renvoyée par KeyStone est :


• http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de

La fin de l’URL du endpoint de Cinder est l’iden fiant du projet :


stack@microwave:~$ openstack project show demo
+-------------+----------------------------------+
| Field | Value |
+-------------+----------------------------------+
| description | |
| domain_id | default |
| enabled | True |
| id | 3f36cd33d14e468293caa7bf311c00de |
| is_domain | False |
| name | demo |
| parent_id | default |
| tags | [] |
+-------------+----------------------------------+

U lisa on de l’API Cinder : Obtenir la liste des volumes


Nous allons u liser l’API Cinder pour obtenir la liste des volumes de notre projet, à tre de
comparaison la liste des volumes obtenue en u lisant le CLI est la suivante :
stack@microwave:~$ openstack volume list
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| ID | Name | Status | Size | Attached to |
+--------------------------------------+------------------+-----------+------+--------------------------------------------+
| 609fd47f-0c07-46b6-925a-46e8abadeb89 | donnees | available | 5 | |
| 417394d7-dc15-48ec-9f22-09b034019459 | ubuntu-16.04_vol | in-use | 10 | Attached to ubuntu-16.04_inst on /dev/vda |
+--------------------------------------+------------------+-----------+------+--------------------------------------------+

Il s’agit d’un des cas les plus simples d’u lisa on d’une API, la documenta on de ce e API est
disponible à ce e adresse :
• h ps://developer.openstack.org/api-ref/block-storage/v3/index.html#list-accessible-volumes-with-details

90 Minutes avec OpenStack – 2019/11/11 85


Pour obtenir la liste des volumes de notre projet il nous suffit de faire un ‘GET’ en HTTP et d’u liser
comme URL celle du endpoint retournée par KeyStone (qui con ent l’id de notre projet) et de
rajouter ‘/volumes/detail’ à la fin :
• http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/detail

Nous récupérons le token KeyStone en appelant l’API KeyStone et nous le plaçons dans la variable
MON_TOKEN, puis nous appelons l’API de Cinder en u lisant le endpoint renvoyé par KeyStone en
même temps que le token, nous ajoutons un entête HTTP ‘X-Auth-Token’ :
stack@microwave:~$ export MON_TOKEN=gAAAAABarDI1U6c4sJJW8WRYQ4jJ1 […/…] qKHBezi8iFTHZicYkp4dq4_JZj9XDQ

stack@microwave:~$ curl --silent \


--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/detail" | python -m json.tool
{
"volumes": [
⇒ PREMIER VOLUME
{
"attachments": [],
"availability_zone": "nova",
"bootable": "false",
"consistencygroup_id": null,
"created_at": "2018-03-03T16:07:40.000000",
"description": "",
"encrypted": false,
"id": "609fd47f-0c07-46b6-925a-46e8abadeb89",
"links": [
{
"href": "http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/609fd47f-0c07-46b6-925a-
46e8abadeb89",
"rel": "self"
},
{
"href": "http://192.168.1.211/volume/3f36cd33d14e468293caa7bf311c00de/volumes/609fd47f-0c07-46b6-925a-
46e8abadeb89",
"rel": "bookmark"
}
],
"metadata": {
"readonly": "False"
},
"multiattach": false,
"name": "donnees",
"os-vol-tenant-attr:tenant_id": "3f36cd33d14e468293caa7bf311c00de",
"replication_status": null,
"size": 5,
"snapshot_id": null,
"source_volid": null,
"status": "available",
"updated_at": "2018-03-04T21:15:53.000000",
"user_id": "cf025806abdb476f936a72573a8ae66f",
"volume_type": "lvmdriver-1"
},
⇒ SECOND VOLUME
{
"attachments": [
{
"attached_at": "2018-02-18T16:46:57.000000",
"attachment_id": "75c0ad36-7aa9-475d-b830-ec2d6a93123b",
"device": "/dev/vda",
"host_name": null,
"id": "417394d7-dc15-48ec-9f22-09b034019459",
"server_id": "39ea09c2-659a-4b2a-9552-71fcee89ef4a", ⇒ ID du serveur ubuntu-16.04_inst
"volume_id": "417394d7-dc15-48ec-9f22-09b034019459"
}
],
"availability_zone": "nova",
"bootable": "true",
"consistencygroup_id": null,
"created_at": "2018-02-18T16:08:57.000000",
"description": null,
"encrypted": false,
"id": "417394d7-dc15-48ec-9f22-09b034019459",
"links": [
{
"href": "http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/417394d7-dc15-48ec-9f22-
09b034019459",
"rel": "self"
},
{

90 Minutes avec OpenStack – 2019/11/11 86


"href": "http://192.168.1.211/volume/3f36cd33d14e468293caa7bf311c00de/volumes/417394d7-dc15-48ec-9f22-
09b034019459",
"rel": "bookmark"
}
],
"metadata": {
"attached_mode": "rw",
"readonly": "False"
},
"multiattach": false,
"name": "ubuntu-16.04_vol",
"os-vol-tenant-attr:tenant_id": "3f36cd33d14e468293caa7bf311c00de",
"replication_status": null,
"size": 10,
"snapshot_id": null,
"source_volid": null,
"status": "in-use",
"updated_at": "2018-02-18T16:46:57.000000",
"user_id": "cf025806abdb476f936a72573a8ae66f",
"volume_image_metadata": {
"checksum": "9cb8ed487ad8fbc8b7d082968915c4fd",
"container_format": "bare",
"disk_format": "qcow2",
"image_id": "0885d2ea-9445-4a6a-ab45-61ecd42e01d8",
"image_name": "ubuntu-16.04",
"min_disk": "0",
"min_ram": "0",
"size": "289603584"
},
"volume_type": "lvmdriver-1"
}
]
}

Si vous u lisez un token incorrect ou expiré vous allez avoir une erreur d’authen fica on
(HTTP 401) :
{
"error": {
"code": 401,
"message": "The request you have made requires authentication.",
"title": "Unauthorized"
}
}

U lisa on de l’API Cinder : Créa on d’un volume


Nous allons créer un volume à par r d’une image, comme nous l’avions fait en u lisant le CLI
OpenStack.

La documenta on de l’API correspondante est disponible à ce e adresse :

• h ps://developer.openstack.org/api-ref/block-storage/v3/index.html#create-a-volume

Ce e opéra on est réalisée par un ordre POST, le nom du projet est passé dans l’URL (path) de la
même façon que nous avions obtenu la liste des volumes, les autres paramètres sont passés dans le
corps de la requête au format JSON.

Nous commençons par obtenir l’id de l’image Ubuntu à par r de laquelle nous allons créer le
volume, nous pouvons u liser le CLI OpenStack pour bien sûr u liser l’API pour obtenir ce e
informa on :
stack@microwave:~$ curl --silent \
--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211/image/v2/images" | python -mjson.tool
{
[…/…]
"id": "0885d2ea-9445-4a6a-ab45-61ecd42e01d8",
"min_disk": 0,

90 Minutes avec OpenStack – 2019/11/11 87


"min_ram": 0,
"name": "ubuntu-16.04",
"owner": "f5863f4d4266400cbb2562001ea22eba",
[…/…]
}

Nous allons créer un volume de 10Go, qui aura pour nom ‘ubuntu_volapi’, tout comme lorsque
nous avions créé le volume en u lisant le CLI openstack nous voyons que le statut du volume est
‘creating’ et qu’il n’est pas bootable.
stack@microwave:~$ curl --silent \
--request POST \
--header "X-Auth-Token: $MON_TOKEN" \
--header "Content-Type: application/json" \
--data '
{"volume": {
"size": "10",
"name": "ubuntu_volapi",
"imageRef": "0885d2ea-9445-4a6a-ab45-61ecd42e01d8"
}
}' \
"http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes" | python -mjson.tool
{
"volume": {
"attachments": [],
"availability_zone": "nova",
"bootable": "false",
"consistencygroup_id": null,
"created_at": "2018-03-17T17:24:55.000000",
"description": null,
"encrypted": false,
"id": "160ce17d-df05-43b5-b262-0327f3d0d994",
"links": [
{
"href": "http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/160ce17d-df05-43b5-b262-
0327f3d0d994",
"rel": "self"
},
{
"href": "http://192.168.1.211/volume/3f36cd33d14e468293caa7bf311c00de/volumes/160ce17d-df05-43b5-b262-
0327f3d0d994",
"rel": "bookmark"
}
],
"metadata": {},
"multiattach": false,
"name": "ubuntu_volapi",
"replication_status": null,
"size": 10,
"snapshot_id": null,
"source_volid": null,
"status": "creating",
"updated_at": null,
"user_id": "cf025806abdb476f936a72573a8ae66f",
"volume_type": "lvmdriver-1"
}
}

Nous interrogeons l’API d’OpenStack pour vérifier quand notre volume est disponible, on note au
passage qu’il devient bootable, ce qui nous perme ra de lancer une instance à par r de ce volume.
• h ps://developer.openstack.org/api-ref/block-storage/v3/index.html#show-a-volume-s-details

stack@microwave:~$ curl --silent \


--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/160ce17d-df05-43b5-b262-0327f3d0d994" \
| python -mjson.tool
{
"volume": {
"attachments": [],
"availability_zone": "nova",
"bootable": "true",
"consistencygroup_id": null,
"created_at": "2018-03-17T17:24:55.000000",
"description": null,
"encrypted": false,
"id": "160ce17d-df05-43b5-b262-0327f3d0d994",
"links": [
{
"href": "http://192.168.1.211/volume/v3/3f36cd33d14e468293caa7bf311c00de/volumes/160ce17d-df05-43b5-b262-
0327f3d0d994",
"rel": "self"

90 Minutes avec OpenStack – 2019/11/11 88


},
{
"href": "http://192.168.1.211/volume/3f36cd33d14e468293caa7bf311c00de/volumes/160ce17d-df05-43b5-b262-
0327f3d0d994",
"rel": "bookmark"
}
],
"metadata": {},
"multiattach": false,
"name": "ubuntu_volapi",
"os-vol-tenant-attr:tenant_id": "3f36cd33d14e468293caa7bf311c00de",
"replication_status": null,
"size": 10,
"snapshot_id": null,
"source_volid": null,
"status": "available",
"updated_at": "2018-03-17T17:24:57.000000",
"user_id": "cf025806abdb476f936a72573a8ae66f",
"volume_image_metadata": {
"checksum": "9cb8ed487ad8fbc8b7d082968915c4fd",
"container_format": "bare",
"disk_format": "qcow2",
"image_id": "0885d2ea-9445-4a6a-ab45-61ecd42e01d8",
"image_name": "ubuntu-16.04",
"min_disk": "0",
"min_ram": "0",
"size": "289603584"
},
"volume_type": "lvmdriver-1"
}
}

U lisa on de l’API Compute: Créa on d’une instance


Nous allons u liser le volume que nous venons de créer pour créer une instance, nous avons déjà
l’id du volume, il nous faut l’id d’un gabarit (flavor), l’id de notre réseau privé ainsi que le nom
d’une clé publique.

L’API pour obtenir la liste des gabarits est la suivante :

• h ps://developer.openstack.org/api-ref/compute/#list-flavors

Il vous est laissé à tre d’exercice d’u liser l’API compute pour récupérer l’id du gabarit
‘m1.small’

Indice: Il vous faut le endpoint de l’API ‘compute’.

La descrip on de l’API pour obtenir les détails d’un gabarit est la suivante :

• h ps://developer.openstack.org/api-ref/compute/#show-flavor-details

Il vous est laissé à tre d’exercice d’u liser l’API compute pour récupérer les caractéris ques
du gabarit ‘m1.small’ (à par r de son id)

Il est également nécessaire de spécifier à quel réseau connecter le serveur, nous allons le connecter
au réseau privé (‘private’), nous devons obtenir son id grâce à l’API Neutron :

• h ps://developer.openstack.org/api-ref/network/v2/index.html#list-networks
stack@microwave:~$ curl --silent \
--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211:9696/v2.0/networks.json" | python -mjson.tool
{
"networks": [
{
[…/…]
"id": "087bc8a1-65e2-4747-b96e-4dd421c542e5",
"name": "public",

90 Minutes avec OpenStack – 2019/11/11 89


[…/…]
"id": "8e7ebaa8-a44e-4a94-9060-9d5fc6143ddf",
"name": "private",
[…/…]
}

La dernière informa on importante est le nom de la clé publique à u liser :

• h ps://developer.openstack.org/api-ref/compute/#list-keypairs
stack@microwave:~$ curl --silent \
--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211/compute/v2.1/os-keypairs" | python -mjson.tool
{
"keypairs": [
{
"keypair": {
"fingerprint": "8c:56:76:56:d9:de:50:81:8b:4d:6c:b1:ee:55:b2:ae",
"name": "Foucher Laurent RSA",
"public_key": "ssh-rsa
AAAAB3NzaC1yc2EAAAADAQABAAACAQDSjnEGxaX1FsDqp6x2TrYACUWCQgHiq5YGtfdZ5O1z7F5ic9z57Cf5zYgRme40WUpB+6JW8Qv6Jbw8mswyTLjgYGxh97Hp3
5vg3SBIrVfEoGw7jYwRmo2Xf5zMx1orxNcTUnvSGRusoY6CdR28129sfzsIxV7Zh9EMisDt6lXra+CdescSQG3UNiQ0KcIoS24N/
zyImdkXkxrDeeqHPiw9FFNpAbFnwNQx7VCwiwJgjII2wVSYYYBcnpTRzqU8PL0HSU9xcDKn5n9iuD8pFAieF1nSP6k2e6E7hOuPEkIkSkemUedUS6t2BS+pUZqg4b
bMDcSCz7OL0acjyvdHmlkcdjNJzPsEFdqZ7eKBTwkOFS3ot7brpRtG8AMjDKx0KQHUawm8S2vPW3RjhD4QB2osPpvmokKLyvP4mZy0II3RN9ga69nwntKEBGUbclA
wBEQwUE0l0MhknLymVbABtbmllO54X8R940LTyVfXC92RXL/F3j5iJB91WtUwf5ODLB96rp09I4IJI31oEkW7r0cV2NbvusYSZBaD/
PVZoV9h5i2oz8UospaGHjoce4cJG+ZOLKB/lUM778rXVL/
oFFm2TRMEOH4x2yBq0EyJo4o+cOquWhj29FFCB2yylpWhpi42Nf80qXM0d7jKxwaKkS7R7ZdM1eAJ44B/gV57Msqiiw== Foucher, Laurent\n"
}
}
]
}

Nous avons maintenant toutes les informa ons nécessaires pour créer une instance,

La descrip on de l’API qui permet de créer une instance est disponible à ce e adresse :

• h ps://developer.openstack.org/api-ref/compute/#create-server
stack@microwave:~$ curl --silent \
--request POST \
--header "X-Auth-Token: $MON_TOKEN" \
--header "Content-Type: application/json" \
--data '
{"server": {
"name": "ubuntu_instapi",
"flavorRef": "2",
"networks": [{
"uuid": "8e7ebaa8-a44e-4a94-9060-9d5fc6143ddf"
}],
"key_name": "Foucher Laurent RSA",
"block_device_mapping_v2": [{
"source_type": "volume",
"destination_type": "volume",
"boot_index": "0",
"uuid": "160ce17d-df05-43b5-b262-0327f3d0d994"
}]
}
}' \
"http://192.168.1.211/compute/v2.1/servers" | python -mjson.tool
{
"server": {
"OS-DCF:diskConfig": "MANUAL",
"adminPass": "4d8L5QtyWvAV",
"id": "564754fa-3bf7-44fb-96ce-41a2cf9f6ee2",
"links": [
{
"href": "http://192.168.1.211/compute/v2.1/servers/564754fa-3bf7-44fb-96ce-41a2cf9f6ee2",
"rel": "self"
},
{
"href": "http://192.168.1.211/compute/servers/564754fa-3bf7-44fb-96ce-41a2cf9f6ee2",
"rel": "bookmark"
}
],
"security_groups": [
{
"name": "default"
}
]
}
}

Nous u lisons l’API compute pour vérifier si notre serveur est disponible :

90 Minutes avec OpenStack – 2019/11/11 90


• h ps://developer.openstack.org/api-ref/compute/#show-server-details
stack@microwave:~$ curl --silent \
--request GET \
--header "X-Auth-Token: $MON_TOKEN" \
"http://192.168.1.211/compute/v2.1/servers/564754fa-3bf7-44fb-96ce-41a2cf9f6ee2" | python -mjson.tool
{
"server": {
"OS-DCF:diskConfig": "MANUAL",
"OS-EXT-AZ:availability_zone": "nova",
"OS-EXT-STS:power_state": 1,
"OS-EXT-STS:task_state": null,
"OS-EXT-STS:vm_state": "active",
"OS-SRV-USG:launched_at": "2018-03-18T11:28:35.000000",
"OS-SRV-USG:terminated_at": null,
[…/…]
"id": "564754fa-3bf7-44fb-96ce-41a2cf9f6ee2",
"image": "",
"key_name": "Foucher Laurent RSA",
"name": "ubuntu_instapi",
"os-extended-volumes:volumes_attached": [
{
"id": "160ce17d-df05-43b5-b262-0327f3d0d994"
}
],
[…/…]
"status": "ACTIVE",
"tenant_id": "3f36cd33d14e468293caa7bf311c00de",
"updated": "2018-03-18T11:28:36Z",
"user_id": "cf025806abdb476f936a72573a8ae66f"
}
}

Il vous est laissé à tre d’exercice d’u liser les API pour associer une adresse IP flo ante au
serveur, le groupe de sécurité qui nous avions créé et qui autorise les connexions en SSH

Vous devriez ensuite être capable de vous connecter à votre serveur en SSH.

U lisa on du client CLI openstack en mode debug


Vous pouvez u liser le client CLI openstack en mode debug pour avoir la liste des appels à l’API avec
leurs paramètres et les données renvoyées par l’API.

Ceci peut vous perme re de récupérer les appels API nécessaires à vos projets (notez au passage que
le token n’est jamais affiché en clair en mode debug, seulement son hash SHA-1) :
stack@microwave:~$ openstack --debug server list
START with options: [u'--debug', u'server', u'list']
[…/…]
REQ: curl -g -i -X GET http://192.168.1.211/compute/v2.1/servers/detail -H "User-Agent: python-novaclient" -H "Accept:
application/json" -H "X-Auth-Token: {SHA1}2bc21fc4fc2075c05d796fa0e72c2d5895da3ece"
http://192.168.1.211:80 "GET /compute/v2.1/servers/detail HTTP/1.1" 200 3196
RESP: [200] Date: Sun, 18 Mar 2018 13:25:20 GMT Server: Apache/2.4.18 (Ubuntu) Content-Length: 3196 Content-Type:
application/json OpenStack-API-Version: compute 2.1 X-OpenStack-Nova-API-Version: 2.1 Vary: OpenStack-API-Version,X-
OpenStack-Nova-API-Version x-openstack-request-id: req-3f13e308-890e-4681-ba83-d66e2e188800 x-compute-request-id: req-
3f13e308-890e-4681-ba83-d66e2e188800 Connection: close
RESP BODY: {"servers": [{"OS-EXT-STS:task_state": null, "addresses": {"private": [{"OS-EXT-IPS-MAC:mac_addr":
"fa:16:3e:9d:db:6c", "version": 4, "addr": "10.0.0.7", "OS-EXT-IPS:type": "fixed"}, {"OS-EXT-IPS-MAC:mac_addr":
"fa:16:3e:9d:db:6c", "version": 6, "addr": "fdb0:453a:3cd:0:f816:3eff:fe9d:db6c", "OS-EXT-IPS:type": "fixed"}, {"OS-EXT-IPS-
MAC:mac_addr": "fa:16:3e:9d:db:6c", "version": 4, "addr": "172.24.4.13", "OS-EXT-IPS:type": "floating"}]}, "links": [{"href":
"http://192.168.1.211/compute/v2.1/servers/564754fa-3bf7-44fb-96ce-41a2cf9f6ee2", "rel": "self"}, {"href":
"http://192.168.1.211/compute/servers/564754fa-3bf7-44fb-96ce-41a2cf9f6ee2", "rel": "bookmark"}], "image": "", "OS-EXT-
STS:vm_state": "active", "OS-SRV-USG:launched_at": "2018-03-18T11:28:35.000000", "flavor": {"id": "2", "links": [{"href":
"http://192.168.1.211/compute/flavors/2", "rel": "bookmark"}]}, "id": "564754fa-3bf7-44fb-96ce-41a2cf9f6ee2",
[…/…]
+--------------------------------------+-------------------+--------+----------- ... -+----------+
| ID | Name | Status | Networks | Flavor |
+--------------------------------------+-------------------+--------+----------- ... -+----------+
| 564754fa-3bf7-44fb-96ce-41a2cf9f6ee2 | ubuntu_instapi | ACTIVE | private=10 | m1.small |
| 39ea09c2-659a-4b2a-9552-71fcee89ef4a | ubuntu-16.04_inst | ACTIVE | private=10 | m1.small |
+--------------------------------------+-------------------+--------+----------- ... -+----------+
clean_up ListServer:
END return value: 0

90 Minutes avec OpenStack – 2019/11/11 91


90 Minutes avec OpenStack – 2019/11/11 92
Conclusion
J’espère que ce e introduc on à l’u lisa on de OpenStack vous a plu.

N’oubliez pas de visiter régulièrement mon blog : h ps://blog.u03.fr/

N’hésitez pas à me faire part de vos remarques, soit en commentant sur mon blog ou directement
par email : u03@u03.fr

90 Minutes avec OpenStack – 2019/11/11 93

Vous aimerez peut-être aussi