Drbd

De The Linux Craftsman
Aller à la navigation Aller à la recherche

Introduction

DRBD (Distributed Replicated Block Device) est un mécanisme de stockage distribuée qui permet la réplication en mode bloc (disques ou partitions) entre plusieurs machines.

La réplication des données se fait :

  • en temps réel ;
  • de façon transparente pour les applications (qui n'ont pas conscience de la réplication) ;
  • de façon synchrone, ou asynchrone (l'application qui déclenche une écriture de donnée est notifiée de la fin de l'opération après la synchronisation ou avant).

DRBD peut servir conjointement avec Ucarp pour monter un cluster de serveur Web ou autre.

Pour le faire fonctionner il vous faut deux serveurs avec deux disques identiques (en plus du disque système) !

Préparation

Dans un premier temps, il faudra avoir une connexion à Internet, utiliser un serveur DNS et désactiver SELinux.

Pour ceux qui auraient manqué des étapes les voici:

Ensuite il faudra :

  • deux disques identiques (un dans chaque machine) ;
  • la synchronisation des horloges avec NTP ;
  • ouvrir le port TCP 7789.

Une fois ces étapes effectuées, entrons dans le vif du sujet !

Installation de DRBD

DRBD est présent dans le dépôt EL et il faudra donc l'installer comme c'est expliqué ici

Une fois l'installation du dépôt EL nous pouvons installer DRBD:

# yum -y install drbd84-utils.x86_64 kmod-drbd84.x86_6

Pour charger le module dans le noyau un redémarrage est nécessaire !

Configuration

Résolution DNS

Sur les deux machines dans le fichier /etc/hosts ajoutez les lignes suivantes:

192.168.100.135 node1 node1.tala-informatique.fr
192.168.100.136 node2 node2.tala-informatique.fr

Remplacez les adresses IP par celles de vos machines.

Synchronisation de l'horloge

Il faut que les horloges des deux machines soient synchrones pour que DRBD fonctionne:

# yum -y install ntp

Puis:

# service ntpd start

Ouverture du pare-feu

On ouvre le port TCP 7789 puis on sauvegarde la configuration Iptables

# iptables -I INPUT 2 -p tcp --dport 7789 -j ACCEPT
# service iptables save

Création d'une partition principale

Sur les deux machines vous devez partitionner le disque qui servira pour DRBD.

Consultez la page sur la gestion des disques pour voir comment faire.

DRBD

Fonctionnement

Le format des fichiers de configuration à été développé pour pouvoir faire une copie du fichier sur les deux machine (plus simple à gérer). Le fichier /etc/drbd.conf doit donc être le même sur toutes les machines du cluster.

Par convention, le fichier de configuration contient deux inclusion:

  • /etc/drbd.d/global_common.conf
  • tous les fichiers en .res qui se trouvent dans le dossier /etc/drbd.d

Pour résumer :

  • on ne touche jamais à /etc/drbd.conf
  • on ajoute les clusters dans le répertoire /etc/drbd.d dans un fichier qui se termine par .res

Fichier de cluster

Éditez le fichier /etc/drbd.d/cluster.res comme suit :

resource cluster {
        net {
                cram-hmac-alg sha1;
                shared-secret "tala-informatique";
        }
        on node1 {
                device    minor 1;
                disk      /dev/sdb1;
                meta-disk internal;
                address   192.168.100.135:7789;
        }
        on node2 {
                device    minor 1;
                disk      /dev/sdb1;
                meta-disk internal;
                address   192.168.100.136:7789;
        }
}

On n'oublie pas de le copier sur l'autre machine:

# scp /etc/drbd.d/cluster.res root@node2:/etc/drbd.d/

Création du cluster

On doit initialiser le cluster pour qu'il soit utilisable:

# drbdadm create-md cluster
Writing meta data...
initializing activity log
NOT initialized bitmap
New drbd meta data block successfully created.
success

Démarrage du service

On démarre DRBD en simultané sur les deux machines, sinon plantage !

# service drbd start
Starting DRBD resources: [ d(cluster) n(cluster) ]..........
***************************************************************
 DRBD's startup script waits for the peer node(s) to appear.
 - In case this node was already a degraded cluster before the
   reboot the timeout is 0 seconds. [degr-wfc-timeout]
 - If the peer was available before the reboot the timeout will
   expire after 0 seconds. [wfc-timeout]
   (These values are for resource 'cluster'; 0 sec -> wait forever)
 To abort waiting enter 'yes' [  14]:
.

Il doit démarrer comme cela:

# service drbd start
Starting DRBD resources: [ s(cluster) ].

Puis on l'enregistre dans le chargeur de démarrage:

# chkconfig drbd on