Voila un petit script pour tous ceux qui voudraient faire des sauvegardes de leur base de donnée.

<?php
// création d'une fonction comportant les identifiants de connexion au FTP :


function mysql_structure() {
$host = 'mon_serveur';
$user = 'mon_login';
$pass = 'mot_de_passe';
$base = 'nom_de_la_base';

// création d'un fichier affichant en boucle le contenu des tuples de la base :

mysql_connect($host, $user, $pass);
mysql_select_db($base);
$tables = mysql_list_tables($base);
while ($donnees = mysql_fetch_array($tables))
{
$table = $donnees[0];
$res = mysql_query("SHOW CREATE TABLE $table");
if ($res)
{
$insertions = "";
$tableau = mysql_fetch_array($res);
$tableau[1] .= ";";
$dumpsql[] = str_replace("\n", "", $tableau[1]);
$req_table = mysql_query("SELECT * FROM $table");
$nbr_champs = mysql_num_fields($req_table);
while ($ligne = mysql_fetch_array($req_table))
{
$insertions .= "INSERT INTO $table VALUES(";
for ($i=0; $i<=$nbr_champs-1; $i++)
{
$insertions .= "'" . mysql_real_escape_string($ligne[$i]) . "', ";
}
$insertions = substr($insertions, 0, -2);
$insertions .= ");\n";
}
if ($insertions != "")
{
$dumpsql[] = $insertions;
}
}
}
return implode("\r", $dumpsql);
}


// creation d'une fonction file_put_content si le script est en PHP4 :

if(!function_exists('file_put_contents')) {
function file_put_contents($filename, $data, $file_append = false) {
$fp = fopen($filename, (!$file_append ? 'w+' : 'a+'));
if(!$fp) {
trigger_error('file_put_contents ne peut pas écrire dans le fichier.', E_USER_ERROR);
return;
}
fputs($fp, $data);
fclose($fp);
}
}


// création du fichier de dump sur le même niveau que ce fichier dump.php

file_put_contents("sqldump_".date("d-n-Y").".sql", mysql_structure());

// effacement du fichier precedant (créé 7 jours plus tot)
$time_old = getdate(mktime()-(7*24*3600));
$an = $time_old['year'];
$mois = $time_old['mon'];
$jour = $time_old['mday'];


// formatage des jours à 1 chiffre

for($k=1; $k<10; $k++)
{
if ($jour==$k)
{
$jour='0'.$jour;
}
}

$date_old=$jour.'-'.$mois.'-'.$an;
$file_old="sqldump_".$date_old.".sql";
unlink($file_old);
?>

Le script n’est pas de moi, je l’ai honteusement pompé sur webtolosa (la flemme de coder un truc qui existe déjà, je sais, c’est mal).Vous devrez peut-être commenter l’avant dernière ligne (lui rajouter des « // » devant), sous peine de voir un beau message d’erreur lors de la première exécution du script.

Vous pouvez bien sur améliorer le script pour qu’il compresse le fichier sql, pour qu’il fasse une sauvegarde de vos fichiers et place le tout dans un fichier .tar.bz2, et par exemple qu’il vous envoie le tout par mail (attention à la taille des pièces jointes dans ce cas là, si c’est trop gros ça risque de ne pas s’envoyer).

L’avantage avec le script php est que vous pouvez le lancer vous même en vous rendant dessus, ou vous pouvez l’intégrer dans une page de spécifique de votre site.

Pour le faire tourner automatiquement chez ovh (peut-être un rapport avec le fait que je soit passé chez eux hier …) c’est simple, uploadez le script dans votre FTP (dans le répertoire /home/votre_login/www/ ), passez le en chmod 704, ainsi vous pouvez l’exécuter vous même depuis le web.
Bon là tout le monde peux le lancer donc arranger vous pour lui donner un nom bien dur à trouver du style « mega_back-up_de_la—b-a-s-e–my_sql.php » ainsi les gens ne s’amuseront pas à le lancer pour vous (et faire ramer votre site par la même occasion, surtout si la base de donnée est grosse).

Rendez-vous ensuite dans votre interface d’administration, allez dans la gestion de votre hébergement, et ensuite dans « planificateur de tâches ».

Planificateur de taches ovh - t0m-s -

Créez une nouvelle tache, et renseignez l’endroit où se trouve votre script php, indiquer quand vous voulez qu’il s’exécute et enregistrez les modifications, voila, une sauvegarde vous attendra dans votre ftp tout les jeudi minuit par exemple.

Si vous ne comprenez pas quelque chose demandez moi.

Sous WordPress il y a une fonction de formatage automatique, c’est à dire qu’elle rectifie ce que vous avez écrit (s’il y a une faute dans le code html par exemple).

Logo WordPress - t0m-s -

Cet outil est plutôt bien foutu, mais parfois il peut être énervant, surtout quand vous devez écrire des lignes de code, car, par exemple, un double tiret « — » sera remplacé par un long « &#8212″ et un double tiret entouré d’espace  » —  » sera remplacé par un autre type de tiret long « &#8211 ».

Bon si c’est dans du texte normal c’est pas bien grave, mais quand c’est dans une ligne de code shell comme dans mon article pour faire fonctionner sa palette graphique sous linux ça peut être embêtant (car le code ne va simplement pas marcher).

Il y a un moyen simple pour remédier à cela: modifier un fichier php de WordPress.

Avec un logiciel FTP téléchargez ce fichier

/wp-includes/formatting.php

Ensuite pour empêcher WP de transformer vos doubles tirets en long tiret tout pas beau qui plante tout votre code écrit avec amour il va falloir modifier quelque peu ce fichier.

Trouver la ligne contenant

$static_characters = array_merge(array(‘—‘, ‘ — ‘, ‘–‘, ‘ – ‘, ‘xn&amp;#8211;’, ‘…’, ‘« ‘, ‘\’s’, ‘\’\ », ‘ ™’), $cockney);

et supprimez y les deux occurrences du double tiret ( ‘ — ‘ et ‘–‘ ) vous obtiendrez donc

$static_characters = array_merge(array(‘—‘, ‘ – ‘, ‘xn&amp;#8211;’, ‘…’, ‘« ‘, ‘\’s’, ‘\’\ », ‘ ™’), $cockney);

Ensuite à la ligne suivante

$static_replacements = array_merge(array(‘&amp;#8212;’, ‘ &amp;#8212; ‘, ‘&amp;#8211;’, ‘ &amp;#8211; ‘, ‘xn--‘, ‘&amp;#8230;’, $opening_quote, ‘&amp;#8217;s’, $closing_quote, ‘ &amp;#8482;’), $cockneyreplace);

Retirez ‘ &#8212; ‘ et  ‘&#8211;’ qui correspondent respectivement aux ? et ?, vous aurez donc une ligne qui ressemble à cela

$static_replacements = array_merge(array(‘&amp;#8212;’, ‘ &amp;#8211; ‘, ‘xn--‘, ‘&amp;#8230;’, $opening_quote, ‘&amp;#8217;s’, $closing_quote, ‘ &amp;#8482;’), $cockneyreplace);

Faite une sauvegarde du nouveau fichier pour pouvoir le restaurer en cas de mise à jour, ou éditez ses droits pour que les mises à jour ne puissent pas le modifier (mais vérifier quand même qu’une faille de sécurité n’a pas été découverte entre temps, on est jamais trop prudent).

Vous pouvez bien sur modifier le code pour qu’il ne remplace plus rien du tout, dans ce cas là je vous laisse faire.

En espérant que ça vous soit utile, bonne soirée.