Manual:Restoring a wiki from backup/fr

Le wiki doit être sauvegardé régulièrement, même s'il vous n'avez jamais besoin de le restaurer : les sauvegardes rassurent. D'un autre côté la sauvegarde est inutile si vous ne pouvez pas restaurer, et s'entraîner à restaurer enlève l'angoisse à venir. D'où ces instructions.



Versions et mise à jour
Les instructions de cette page sont en majorité applicables à pratiquement toutes les versions de MediaWiki. Vous pouvez restaurer la base de données vers une version plus récente de MediaWiki, mais assurez-vous de bien exécuter le script de mise à jour. Par contre il ne vous est pas permis de restaurer une base de données issue d'une version récente, dans une version plus ancienne du logiciel.



Transfert de fichiers
A moins que vous ayez un accès direct au serveur qui héberge votre wiki (et même dans ce cas) il vous faudra choisir une méthode pour transférer les fichiers :


 * Secure copy with SCP or WinSCP
 * SSH File Transfer Protocol (SFTP)
 * Using a FTP client.
 * The hosting company might provide a file manager interface via the web browser, check with your provider.
 * Some other method, there is a list of these at List of file transfer protocols

Vue d’ensemble

 * 1) recréer la base de données, l'utilisateur avec ses droits
 * 2) importer la sauvegarde de la base de données
 * 3) importer les fichiers MediaWiki
 * 4) vérifier le fichier de configuration
 * 5) tester



Recréer la base de données, les utilisateurs et les droits
Sur le serveur où vous restaurez MediaWiki, assurez-vous d'avoir


 * 1) une instance fonctionnelle de MySQL
 * 2) un utilisateur MySQL avec les droits suffisants dans le cas où vous ne pourriez pas utiliser l'utilisateur root de MySQL

Si vous restaurez à partir d'une sauvegarde suite à une base de données corrompue, vous devez réinstaller MySQL ! Une fois que MySQL fonctionne correctement, créez une nouvelle base de données MySQL et attribuez les droits de votre compte utilisateur sur la base de données comme listés ci-dessous. Vous pouvez consulter la documentation MySQL, la documentation du panneau de contrôle de votre fournisseur d'hébergement, ou la documentation de tout autre utilitaire que vous utilisez, pour vous renseigner sur la manière de faire cela. A partir de l'invite MySQL et en tant qu'utilisateur MySQL root, vous pouvez :

CREATE DATABASE wikidb; CREATE USER wikidb_user IDENTIFIED BY &#39;wikidb_userpassword&#39;; USE wikidb; GRANT SELECT, UPDATE, INSERT, DELETE, ALTER, CREATE, INDEX, DROP, LOCK TABLES, USAGE ON wikidb.* TO wikidb_user;



Importer la sauvegarde d'une base de données
Puis importez la sauvegarde de votre base de données. Cela va créer les tables de la base de données et les remplir avec les données. L'import requiert un temps variable, qui dépend du nombre de pages, d'utilisateurs, de modifications, etc. réalisées dans votre wiki.

Méthodes


A partir de la ligne de commande en utilisant
S'il existe déjà une base de données et que vous souhaitez la remplacer entièrement par le contenu de la sauvegarde. Pour supprimer la base de données :

mysqladmin -u wikidb_user -p drop wikidb

adapter  et   selon le cas. Le paramètre  sert à vous demander le mot de passe.

Ensuite pour créer une nouvelle base de données :

mysqladmin -u wikidb_user -p create wikidb

For example after backing up with mysqldump: mysqldump --default-character-set=binary --user=wikidb_user --password=wikidb_userpassword wikidb > dump_of_wikidb.sql
 * 1) Don't do this now: This is how you might have created a backup earlier.
 * 1) The wikidatabase wikidb from which you backed up may have a different name
 * 2) than the wikidatabase wikidb you've created above. Of course wikidb_user and
 * 3) wikidb_userpassword may be different as well.

Assurez-vous d'avoir spécifié le bon ensemble de caractères sinon la restauration peut échouer, vérifier  pour connaître l'ensemble des caractères utilisé.

Pour importer  à partir de la ligne de commande faites simplement :

mysql -u wikidb_user -p wikidb < dump_of_wikidb.sql

puis si nécessaire faites :

php wikifolder/maintenance/update.php
 * 1) Most people name their wikifolder simply "w", making this pathname
 * 2) something like "htdocs/w/maintenance/update.php"

Voir aussi Exécuter les commandes SQL à partir d'un fichier texte



Avec le navigateur pour phpMyAdmin
Ouvrir le navigateur de phpMyAdmin, se connecter, sélectionner la base de données du wiki (voir le fichier LocalSettings.php si vous n'êtes pas sûr). Sélectionner 'Structure', 'localhost', votre_table. Sélectionner 'CheckAll'. Dans le menu déroulant, sélectionner 'Drop', puis 'Ok' pour effacer la table. Cliquer sur 'Importer', sélectionner 'Browse', choisir votre fichier SQL et l'importer. Presser. N'oubliez pas non plus de sauvegarder les composants du système de fichiers qui pourraient être nécessaires, par exemple les images, le logo et les extensions, (voir le sujet MySql ci-dessus).

En fonction du temps maximum autorisé pour configurer et de la taille du fichier SQL, vous pourriez avoir à réitérer les opérations d'import avant d'avoir ramené tous les éléments. Si l'import de la totalité de la base de données n'a pas pu être réalisé, celle-ci peut être dans un état incohérent, par exemple avoir des versions absentes.



A partir d'un dump XML
Article principal : 

Pour importer un Special:MyLanguage/Manual:DumpBackup.phpdump XML dans un wiki, utiliser l'outil en mode ligne de command. Faire :

php wikifolder/maintenance/importDump.php --dbpass wikidb_userpassword --quiet --wiki wikidb path-to-dumpfile/dumpfile.xml php wikifolder/maintenance/rebuildrecentchanges.php

Remplacer,  et   selon les besoins.

Puis utiliser pour importer les images : php wikifolder/maintenance/importImages.php wikifolder_backup/images 

Importer les fichiers MediaWiki
Puis restaurez la sauvegarde de votre système de fichiers MediaWiki : c'est l'étape finale assez conséquente du processus de restauration.


 * Si vous avez suivi les instructions du manuel de sauvegarde, et que vous avez enregistré le répertoire global, celui-ci comprendra les répertoires d'images, les extensions, les habillages personnalisés, etc. et le fichier de configuration.
 * Si vous n'avez sauvegardé que des répertoires individuels, comme les images, les extensions, etc. alors il faudra d'abord téléverser ou copier une nouvelle installation des fichiers MediaWiki, puis transférer ces répertoires avec leurs fichiers dans la nouvelle arborescence à leur emplacement respectif.



Pour effacer et restaurer le système de fichiers du wiki
N'oubliez pas non plus de restaurer les composants du système de fichiers qui pourraient être nécessaires, par exemple les images, le logo et les extensions. Particulièrement de corriger  s'il comporte des incohérences. Une séquence de commandes Linux pour effacer et restaurer le système de fichiers du wiki pourrait être :

wget http://download.wikimedia.org/mediawiki/ /mediawiki-.tar.gz tar -xvzf mediawiki-.tar.gz rm mediawiki-.tar.gz rm -fR wikifolder/ mv mediawiki- wikifolder rm -fR wikifolder/extensions/ cp -R wikifolder_backup/extensions wikifolder/extensions

Ouvrir le wiki dans le navigateur et cliquer sur le lien Set up the wiki first permettant de configurer le wiki. Voir pour les détails. Si besoin, vous pouvez exécuter l'installeur  en mode ligne de commande. Une fois ceci réalisé, modifier  pour l'adapter à la nouvelle installation, en restituant les lignes des extensions, etc. Restaurer à partir de la sauvegarde tout autre fichier tel que le logo personnalisé et l'icône favorite avec leur chemin correct.

Si vous n'avez pas fait l'installation en tant qu'utilisateur root sous Linux/Unix et que les images et les vignettes ne fonctionnent pas, vous devrez en corriger le propriétaire ou répercuter les droits d'accès de manière récursive à partir du répertoire contenant les images téléversées (habituellement wikifolder/images).

Vérification du fichier de configuration
La tâche finale comprend la vérification et éventuellemnt la modification du fichier. Vérifiez les options de configuration suivante :
 * Si vous faites la restauration sur le même serveur qui a servi à la sauvegarde, vous n'aurez vraisemblablement rien à modifier.
 * Si vous restaurez sur un nouveau serveur (par exemple lorsque vous déplacez ou dupliquez MediaWiki), il est probable que certaines entrées seront forcément à corriger, de même que pour les informations de connexion à la base de données.

Pensez aussi à vérifier les chemins vers diff3, ImageMagick, etc.

Test
À ce stade, essayez d'utiliser le wiki du nouveau serveur. Connectez-vous en tant que sysop et qu'utilisateur régulier pour vérifiez que l'affichage, la création et l'édition des pages et le téléversement des fichiers fonctionnent toujours. Corrigez tous les problèmes signalés par PHP ou MediaWiki lui-même.



Problèmes fréquents
Après avoir fait le transfert, des avertissements PHP peuvent apparaître disant que certains fichiers ne sont pas accessibles. Il est probable que ce soit le plus souvent causé par T37472 : La colonne md_deps de la table module-deps contient les chemins absolus des fichiers; ils sont utilisés pour localiser les images et les fichiers LESS desquels dépend le CSS. Ces chemins seront cassés si le wiki est déplacé vers un autre répertoire ou mis sur un autre serveur.

En attendant que ce bogue soit résolu, vous pouvez utiliser ce contournement pour corriger manuellement les entrées erronnées de la table module_deps : Cela peut être utilisé pour actualiser les segments erronés du chemin et corriger l'erreur.



Voir aussi

 * (si vous n'avez pas de sauvegarde valide)
 * Script: Fullsiterestore
 * (si vous n'avez pas de sauvegarde valide)
 * Script: Fullsiterestore
 * Script: Fullsiterestore
 * Script: Fullsiterestore



Liens externes

 * Instructions détaillées sur la 'Migration vers un nouveau serveur'