Aller au contenu principal

serveur-sauvegarde

1. Introduction

Pourquoi synchroniser ?

D'un point de vue de l'entreprise, un serveur de synchronisation est utile pour centraliser les sauvegardes sur une même machine équipée accessoirement d'un enregistreur de bande.

Pour le particulier, il est intéressant (si vous avez plusieurs machines), d'avoir une sauvegarde simple et rapide de son répertoire home.

rsync est prévu à cet effet. Il peut même faire plus.

Dans ce tutoriel comment faire une synchronisation entre deux serveurs; un serveur de production et un serveur de centralisation des backups.

Les particularités de rsync

rsync est un outil simple disponible sans installation particulière sous Ubuntu et existant pour divers systèmes d'exploitation. La grande particularité de rsync est d'optimiser la bande passante disponible en compressant les données à synchroniser et en ne transférant que les octets modifiés.

Étude de cas

Pour vous donner une idée de l'amélioration que rsync peut apporter, voici quelques tests que nous avons effectués en entreprise sur un serveur de production.

  • Masse de données : environ 30 Go
  • Taux de modification des données : 1% par heure (environ 250 fichiers)
  • Liaison dédiée 100Mbits entre les deux serveurs.
  • Temps de synchronisation avec parcours de fichiers : 4h30 (du coup, on ne faisait que 3 synchros par jour).
  • Temps de synchronisation avec rsync : 22min (quand on le fait 3x par jour, maintenant, on fait 1 * synchro par heure avec un temps de synchro de 10min).

Petite histoire d'un sysadmin.

Configuration du serveur de synchronisation

Pour autoriser rsync à se lancer, il faut éditer le fichier /etc/default/rsync via la commande :

Step1

  1. Editer le fichier (/etc/default/rsync)
sudo nano /etc/default/rsync
  1. Modifier la ligne RSYNC à true
RSYNC_ENABLE=true

Step2 Pour configurer rsync, on crée le fichier de configuration de rsync en éditant le fichier /etc/rsyncd.conf via la commande :

sudo nano /etc/rsyncd.conf
  1. En entête de ce fichier (/etc/rsyncd.conf), il faut copier les lignes suivantes :

Le démon rsyncd sera lancé en tant qu'utilisateur rsync, et pourra donc écrire dans les répertoires qui lui seront attribués.

uid = rsync
gid = rsync
  1. Dans ce fichier, on introduit les informations concernant les modules. Un module est une sorte de partage rsync. Dans notre cas, on va créer un module nommé share_rsync
[share_rsync]
path = /srv/intern
comment = Synchro fichiers internes
read only = false

Vous pouvez bien entendu créer plusieurs modules de synchronisation.

Il existe également d'autres mots clés à utiliser dans le fichier /etc/rsyncd.conf qui permettent l'authentification et d'autres choses. Vous trouverez de plus amples détails en tapant :

man rsyncd.conf

Step3 Ajouter un utilisateur et un groupe rsync

sudo useradd rsync
sudo passwd rsync
sudo groupadd rsync
sudo gpasswd -a rsync rsync

Step4 Attribuer le répertoire de sauvegarde à rsync

sudo chown -R rsync:rsync /srv/intern

Step5 Attribuer les droits adéquats au répertoire de sauvegarde

sudo chmod -R 775 /srv/intern

Step6

Pour terminer, lancer rsync sans redémarrage avec la commande :

sudo /etc/init.d/rsync start

On peut faire lancer le deamon rsync automatiquement à tous les démarrages du PC en utilisant la commande suivante :

sudo systemctl enable rsync.service

Le serveur est maintenant prêt pour recevoir les requêtes de synchronisation.

Configuration du client

Les synchronisations du (ou des) client(s) peuvent se faire par le biais de la commande rsync. La syntaxe de cette dernière est relativement simple.

rsync -az --stats --delete --force --ignore-errors --exclude-from=/etc/rsync.exclude /srv/intern 192.168.50.12::share_rsync/

Detail de la commande:

  1. Avec cette commande, j'indique que je souhaite supprimer les fichiers (option ​--delete) qui ne sont plus sur la source (la source dans ce cas-ci est /srv/intern), que je souhaite obtenir des statistiques quant à la vitesse de transfert (option ​--stats) et que je souhaite exclure les fichiers listés dans /etc/rsync.exclude (​--exclude-from).

  2. Dans le fichier rsync.exclude, mettre un chemin par ligne (vers un répertoire ou un fichier). Attention, ne pas oublier les / en fin de ligne pour les répertoires ainsi que "- " (moins espace) avant chaque ligne.

Les options clés se trouvant juste après la commande sont explicitées ci-dessous :

  1. a: indique que rsync doit travailler en mode archive, c'est-à-dire qu'une copie fidèle de l'arborescence (et donc des sous répertoires) est réalisée (les permissions, les propriétaires et les dates de modification des fichiers sont conservés).
  2. z : indique à rsync qu'il doit utiliser la compression pour le transfert des données.

La destination de synchronisation (notre serveur) s'indique comme suit :

192.168.50.12::module/

Notez que si vous ne placez pas le / après le module, vous allez obtenir un sous-répertoire intern (dans ce cas-ci) dans le répertoire défini dans le module. Ce qui peut être intéressant dans certains cas mais ce n'est pas le but ici.

Donc, en exécutant cette commande, le répertoire /srv/intern est synchronisé avec le module share_rsync sur le serveur 192.168.50.12.

Sur une station de travail, on peut utiliser cette commande à chaque fois où l'on veut faire un petit backup (c'est ce que je fais à la maison) mais en entreprise, on souhaite que ces synchronisations (ou backup, comme vous voulez) soient faites à des intervalles fixes.

Pour ce faire, nous allons configurer Cron pour lancer les synchronisations automatiquement. Ceci est fait en ajoutant une ligne au fichier /etc/crontab. Par exemple, pour une synchronisation par heure de 7h à 22h :

05 7-22 * * *   root   rsync -raz --stats --delete /srv/intern 192.168.50.12::share_rsync/

N'oubliez pas de forcer le rechargement du crontab via la commande :

sudo /etc/init.d/cron reload

Si l'adresse des fichiers à copier contient des espaces, il faut les remplacer par ? ou \ , par exemple, dans le cas de Windows avec cwrsync :

C:\Mes documents\

devient :

/cygdrive/c/Mes?documents/