1ère étape : Créer le fichier contenant les instructions SQL.
L'utilitaire mysqldump, fourni avec MySQL, est payé pour ça, mais votre outil favori pour travailler avec MySQL doit certainement le faire sans problème.
2ème étape : Compresser le fichier à l'aide de PHP.
Un coup d'oeil à la documentation de PHP renseigne efficacement sur les possibilités de PHP en la matière.
Il supporte le format ZIP, en lecture uniquement, de façon non native, d'autre part les fonctions mises à disposition ne cadrent pas facilement avec notre besoin.
Par contre, il supporte en natif (version 4.3.0+) le format gzip, en particulier sous Windows où tous les utilisateurs n'ont pas forcément à leur disposition un compilateur pour reconstruire PHP à leur goût.
Les fonctions supportées cadrent parfaitement, en fait elles sont très semblables aux fonctions destinées à manipuler les fichiers, la différence étant le préfixe gz à la place du préfixe f (fopen -> gzopen) et un paramètre pour indiquer le niveau de compression (pour gzopen). Il est d'ailleurs possible d'utiliser un wrapper pour manipuler les fichiers avec les fonctions traditionnelles (fopen('zlib://'.$NomFichier,$Mode)), utile si le script doit compresser ou non suivant une condition.
Détail des fonctions utilisées :
$RessourceFichier=gzopen($NomFichier, ModeOuverture,[UseIncludePath])
Où NomFichier est le nom du fichier, avec le chemin si nécessaire. De préférence, utiliser le '/' comme séparateur.
ModeOuverture est une chaine de caractères adapté au besoin, en l'occurrence, pour créer le fichier 'w' pour écrire un nouveau fichier (s'il existe il sera tronqué à 0), suivi d'un 'b', indiquant que les données seront en binaire (et non du texte, pour éviter qu'un caractère Ctrl-Z - EOF - soit interprété comme la fin de fichier) et terminé par un chiffre indiquant le degré de compression souhaité (9 : compression maximale) une meilleure compression étant réalisée au détriment du temps nécessaire.
Pour lire le fichier, ModeOuverture sera 'rb', r: read (lecture) et b: binary (binaire), le taux de compression ne doit pas être précisé et ouvrir un fichier non compressé à l'aide de cette fonction n'est pas génant.
Le troisième paramètre, optionnel, indique s'il est à 1, que le fichier doit également être recherché dans les chemins listés dans le include_path du php.ini.
La fonction retourne FALSE en cas d'échec ou une ressource en cas de succès, utilisable par les autres fonctions du groupe.
Exemple :
$RessourceFichier=gzopen('MonFichier.gz','wb5');
$Chaine=gzgets($RessourceFichier, Entier)
$RessourceFichier doit contenir une ressource valide obtenue grâce à la fonction gzopen.
Cette fonction retourne une chaine de caractères limitée à la longueur Entier-1 ou une nouvelle ligne (le ou les caractères de changement de ligne inclu(s)) ou la fin de fichier ; ce qui survient en premier.
Ici, on considère que les cas qui peuvent se produire sont la fin de fichier ou une ligne complète, en conséquence, ne pas hésiter à spécifier un entier très grand (la limite est 2147483648 :-) pour éviter d'avoir une fraction de ligne que le script ne gérerait pas avec élégance...
$Entier=gzwrite($RessourceFichier, $Chaine)
Cette fonction écrit $Chaine dans le fichier préalablement ouvert avec gzopen et identifié par la ressource $RessourceFichier.
Elle retourne un entier précisant le nombre d'octets (non compressé) écrit dans le fichier.
$Booleen=gzclose($RessourceFichier)
Cette fonction ferme le fichier ouvert avec gzopen, identifié par la ressource $RessourceFichier.
Elle retourne TRUE en cas de succès, FALSE en cas d'échec.
$NbArguments=$argc
Il s'agit du nombre d'arguments envoyés à php par la ligne de commande, y compris le nom complet du script
$Argument=$argv[x]
Renvoie le x ième argument de la ligne de commande, le premier $argv[0] étant le nom complet du script.
Voici un exemple de script capable de le mener à bien. Il est utilisé au mieux avec la version client de PHP, puisqu'il attend ses paramètres par la ligne de commande (dans mon cas, la base 'mère' est sous Access qui se charge de gérer une interface conviviale et de générer le dump). L'extension souhaîtable du fichier de sortie est .gz.
<? if ($argc!=3 echo 'Nombre d\'arguments incorrects !'."\n\r"; echo "Attendu : Chemin complet du fichier SQL chemin complet du fichier de sortie\n\r"; exit(); } $FileIn=fopen($argv[1],'r');// ouverture du fichier source en lecture, mode texte $FileOut=gzopen($argv[2],'wb5');// ouverture du fichier en écriture, niv. compression : 5 while (!feof($FileIn)){ $Ligne=fgets($FileIn,65535);// augmenter le 65535 si besoin gzwrite($FileOut,$Ligne); // écriture de la ligne de texte compressée }// boucle tant que la fin de fichier n'est pas atteinte fclose($FileIn);// fermeture des fichiers gzclose($FileOut); ?> |
Le fichier produit peut être ouvert avec des outils comme WinRAR ou WinZip (ce dernier demande de préciser l'extension afin de le visualiser efficacement, répondez .sql si cette extension est associée correctement, sinon .txt ; de toute façon le fichier ne sera pas modifié).
3ème étape : Transférer le fichier sur le serveur distant.
Utiliser votre méthode habituelle : FTP ou interface WEB, c'est dans cet étape que le gain obtenu par la compression se matérialise, en particulier pour les interfaces WEB qui limitent directement ou indirectement le volume transférable.
4ème étape : Décompressez le fichier et intégrer son contenu à la base de données.
Le script nécessaire doit être installé sur le serveur distant, son exécution lancée à l'aide du navigateur comme n'importe quelle page de votre site.
Le script suivant est capable de réaliser cette tâche. Il est volontairement rudimentaire afin de montrer le principe utilisé. Un script plus convivial est disponible plus bas.
Ce principe est simple : Ouverture du fichier compressé, lecture ligne par ligne, évaluation si la ligne est une commande SQL complète, sinon on concatène, les lignes de commentaires sont ignorées, quand la ligne est complète, exécution par le serveur SQL.