Robocopy

Présentation

Dans le cadre d’une migration de données, migrer les données sans erreur, c’est bien, ne pas avoir à refaire les droits, c’est mieux !

Pourquoi prévoir une longue interruption de la production pour migrer plusieurs centaines de gigaoctets voir de téraoctets? Il est possible de lancer la copie des fichiers du serveur source vers le serveur cible plusieurs jours en avance puis de réaliser une mise à jour incrémentielle de temps en temps afin de n’avoir que très peu de modification à synchroniser.

Ainsi le jour J il ne reste plus qu’à couper l’accès aux utilisateurs à l’ancien serveur, lancer une dernière synchronisation des fichiers récemment modifiés, puis d’établir l’accès sur le nouveau serveur.

Vous pouvez même donner l’ancien nom de serveur au nouveau serveur, ce qui vous évitera de mettre en place des scripts de migration des lecteurs réseaux de vos utilisateurs. Bien entendu s’il suffit de modifier le logon script de vos utilisateurs pour les faire pointer vers le nouveau serveur, un changement de nom ne posera pas de problème. Pensez toutefois à bien communiquer auprès des utilisateurs en leur demandant de ré-ouvrir leur session au moment voulu pour que le nouveau mappage soit pris en compte!

Construire son script

Robocopy propose de nombreuses options parfois complexes et qui seront bien souvent inutiles. Concrètement lorsque l’on veut déplacer des données d’un serveur vers un autre, l’idéal est de conserver exactement la même arborescence et de récupérer les droits NTFS associés.

Pour lancer la copie d’un partage source vers un partage cible il faut lancer la commande suivante:

robocopy “\\serveursource\share” “\\serveurcible\share”

Mais il sera possible d’agrémenter cette commande grâce à de nombreuses fonctionnalités !

/MIR : Cette option permet de reporter les changements de la source vers la cible. Si un fichier est créé sur la source il va être copié vers la cible. Si un fichier est supprimé sur la source, il le sera également sur la cible.
/SEC : Cette autre option géniale permet de migrer également les droits NTFS !
/B : Cette option est très utile si en tant qu’administrateur vous n’avez pas tous les droits NTFS sur certains dossiers. Je vous la conseille donc fortement si vous ne voulez pas être dans l’obligation de vous réapproprier les dossiers en question manuellement pour pouvoir les migrer.
/LOG : Autant garder un historique de la copie. Cette option désactive le « verbose » à l’écran. Voir l’option qui suit !
/TEE : Lorsque l’on utilise /LOG l’intéractivité à l’écran peut être conservé grâce à cette option
/MON:x : Permet de lancer la commande en mode monitor, c’est à dire que la commande va rester active et attendre un certain nombre x de changements apportés sur la source pour les copier sur la cible. Ainsi la première fois tout va être copié et la commande va attendre les changements.
/RH:hhmm-hhmm : Cette option permet de lancer le script qu’à une certaine plage horaire, très pratique si vous préférez lancer la copie la nuit.
/MOT:x : Idem que /MON mais cette fois x correspond à un nombre de minutes d’attente avant de relancer la synchro.

Je lance mes commandes depuis une invite de commande ou depuis un fichier batch si j’ai plusieurs partages localisés un peu n’importe où …

Quelques jours avant le changement de serveur je lance ma première copie grâce à la commande suivante :

robocopy “\\serveursource\share” “\\serveurcible\share” /MIR /SEC /B /RH:2000-0700 /TEE /LOG+:c:\journal.log

De cette manière ma copie se déroule de 20h à 7h du matin. Si mon volume de données à copier est tel que cela n’a pas suffit ! Je peux le relancer une seconde fois, une troisième fois …

Lorsque tout est copié, j’utilise plutôt la commande suivante:

robocopy “\\serveursource\share” “\\serveurcible\share” /MIR /SEC /B /MOT:10 /TEE /LOG+:c:\journal.log

Le script va rester en stand-by et toutes les 10 mn, les changements vont être synchronisés ! Je laisse le script actif jusqu’au jour de la migration, sans stress.

Et pour finir le jour de la bascule, je coupe l’accès aux utilisateurs et je lance :

robocopy “\\serveursource\share” “\\serveurcible\share” /MIR /SEC /B /TEE /LOG+:c:\journal.log

Ensuite je change le nom des serveurs afin de nommer mon nouveau serveur comme l’ancien et ma migration est terminée ! Je prend soin de supprimer mon script afin de ne pas le relancer par accident. Ceci étant l’ancien serveur étant arrêté et renommé, il n’y a pas de risque.

Autre exemple de script :

robocopy “\\serveur\d$\DATA” “D:\DATA” /MIR /SEC /B /TEE /LOG+:c:\journal.log