Rechercher : dans
Par :

Script de sauvegarde en batch

Dernière réponse le 21 fév 2009 à 09:49:30 Dikmas, le 28 oct 2008 à 15:39:47 
 Signaler ce message aux modérateurs

Bonjour,


Alors voila. Je souhaite sauvegarder une base mysql. à ce niveau je n'ai pas de soucis. j'ai rentré mes commandes dans mon fichier batch et j'ai fait une tâche planifié. Le script écrit même le résultat de la sauvegarde dans un fichier log.

Ce que j'aimerais faire et que je ne vois pas du tout comment faire c'est :

pour chaque jours de la semaine lui associer un numéro
lundi --> 1
mardi --> 2
mercredi --> 3
jeudi --> 4
vendredi --> 5
samedi --> 6
dimanche --> pas de sauvegarde, donc pas de numéro.

Donc, on lance la sauvegarde la semaine 1
lundi --> création du fichier "sauv_lundi.sql"
mardi --> création du fichier "sauv_mardi.sql"
mercredi --> création du fichier "sauv_mercredi.sql"
jeudi --> création du fichier "sauv_jeudi.sql"
vendredi --> création du fichier "sauv_vendredi.sql"
samedi --> création du fichier "sauv_samedi.sql"

Les sauvegardes se sont toutes bien faites sans soucis.
Passons maintenant à la semaine 2.

lundi --> la nouvelle sauvegarde écrase le fichier "sauv_lundi.sql" créé lors de la semaine 1
mardi --> etc.

J'espère avoir été clair sur le principe.

merci d'avance.

Configuration: Windows XP
Firefox 3.0.3

Meilleures réponses pour « script de sauvegarde en batch » dans :
Sauvegarde incrémentielle de données avec un .bat (Batch) VoirPourquoi utiliser la sauvegarde incrémentielle ? Sauvegarder vos données importantes avant un formatage par exemple... Au 1er lancement du batch, il sauvegarde l'intégralité des dossiers et fichiers, par contre si vous relancez le batch 2 semaines...
Script au démarrage et à l'arrêt de Windows VoirL'astuce est valable pour Windows XP, Vista et 7 ; mais la méthode varie suivant l'édition de votre Windows (professionnelle ou familiale). Pour les éditions professionnelles ou intégrales Lancer l'éditeur de stratégie du groupe local : Menu...
Sauvegarder les données de l'entreprise VoirLes solutions de sauvegardes de données pour les PME La perte de données stockées sur un ordinateur professionnel peut avoir des conséquences dramatiques pour l'entreprise. Vols, sinistres, défaillance informatique, piratage : l'origine des pertes...

1

chuka, le 28 oct 2008 à 15:47:36

Salut,
soit tu renommes avec la date du jour tes sauvegardes (ainsi jamais le même nom....) et pas écrasée;
soit le dimanche tu fait un bach qui copie les sauvegardes de la semaine dans un répertoire que nomme comme tu veux;
soit tu compresses toutes les sauvegardes de la semaine le dimanche,que tu nommes en fonction du jour, que tu copies dans un répertoire save par exemple.....
J'espère avoir bien compris ta question!!
@+

Répondre à chuka

2

Dikmas, le 28 oct 2008 à 15:53:57

Ce que je veux justement, c'est que les sauvegardes de la semaine 1 soient écrasées par celles de la semaine 2. Qu'il n'y ai que 6 fichiers de sauvegarde, ni plus ni moins.

Répondre à Dikmas

3

chuka, le 28 oct 2008 à 16:21:17

Je viens de tester sur mon poste, si je lance un export de la base appelé 1.sql puis apres je relance un export avec comme nom 1.sql, j'ai bien qu'un fichier, le plus récent....
C'est sous linux ou windows?
Tu pourrais rajouter ,dans le pire des cas, une commande pour effacer la sauvegarde de la semaine précédente avant de lancer l'export...
@+

Répondre à chuka

4

Dikmas, le 28 oct 2008 à 16:25:09

N'avoir qu'un seul fichier de sauvegarde je sais faire aussi, vu qu'il écrase automatiquement l'ancien fichier si le nom n'est pas modifié entre temps.
Mais moi je veux que le lundi il créé "sauv_lundi.sql", le mardi "sauv_mardi.sql" pour la semaine 1. Et pour la semaine 2, il écrase "sauv_lundi.sql" de la semaine 1, le lundi, puis, le mardi de la semaine 2, il écrase "sauv_mardi.sql" de la semaine 2 etc.

Dans mon répertoir backup, j'aimerais avoir 6 fichiers de sauvegarde, un pour chaque jours de la semaine sauf le dimanche.


C'est possible effectivement de faire un script qui supprime les fichiers vieux de plus de 7 jours, mais je ne sais pas faire non plus.

Répondre à Dikmas

5

chuka, le 28 oct 2008 à 16:52:18

Pour linux
#!/bin/bash
cd /PATH
jour=sauv_$(date +%A)
mysqldump -h localhost -u user -ppassword -r$jour.sql base_de_donnée

Répondre à chuka

6

Dikmas, le 29 oct 2008 à 09:32:32

Et pour windows ?

Répondre à Dikmas

7

chuka, le 29 oct 2008 à 09:45:20

Plus compliqué....
je me suis fais exe:(que j'ai appelé jour.exe et qui te retourne le jour dans un fichier jour.txt)
#include <stdio.h>
#include <time.h>
int main ()
{ FILE*pfile;
char* jour[7]={"dimanche","lundi","mardi","mercredi","jeudi","vendredi","samedi"};
pfile=fopen("c:\\TON_CHEMIN\\jour.txt","w");
time_t rawtime;
struct tm * timeinfo;
time ( &rawtime );
timeinfo = localtime ( &rawtime );
fwrite (jour[timeinfo->tm_wday] , 1 ,strlen(jour[timeinfo->tm_wday])*sizeof(char) , pfile );
fclose(pfile);
return 0;
}
apres dans le batch:
cd\PATH
jour.exe
for /F %%a in (jour.txt) do set jour=sauv_%%a
TA_COMMANDE_POUR_LE_DUMP_AVEC_LA_VARIABLE_%JOUR%
del /Q jour.txt

La variable jour récupère le jour...

Répondre à chuka

8

Dikmas, le 29 oct 2008 à 10:04:23

J'ai copié la première partie sur dev c++. Lors de la compilation il me met une erreur :

`strlen' undeclared (first use this function)

pour cette ligne :

fwrite (jour[timeinfo->tm_wday] , 1 ,strlen(jour[timeinfo->tm_wday])*sizeof(char) , pfile );

Je pense qu'il faut déclarer la variable strlen, mais je ne suis pas sûr, et je ne sais pas de quel type elle est.

Répondre à Dikmas

9

chuka, le 29 oct 2008 à 10:08:13

Rajoute la librairie sting.h

Répondre à chuka

10

Dikmas, le 29 oct 2008 à 10:13:23

J'ai la même erreur.

C'est bien #include <sting.h> ? Après tout je peux mal avoir tapé ^^

edit : je viens de voir cette ligne d'erreur : sting.h: No such file or directory.



Pour le batch, j'aimerais savoir si mon fichier est bon :

@ECHO OFF

@ECHO Vous avez choisis de sauvegarder la base menagerie


cd\PATH
jour.exe
for /F %%a in (jour.txt) do set jour=sauv_%%a
mysqldump -u root -proot menagerie > %JOUR%
del /Q jour.txt


SET REUSSI=Sauvegarde de menagerie reussi
SET ECHEC=Sauvegarde de menagerie echouee


@if %ERRORLEVEL% EQU 0 echo %REUSSI% le %JOUR% >> D:\backupmysql\log.txt
@if %ERRORLEVEL% GEQ 1 echo %ECHEC% le %JOUR% code erreur : %ERRORLEVEL% >> D:\backupmysql\log.txt

Répondre à Dikmas

11

chuka, le 29 oct 2008 à 10:15:42

Le batch semble correct!! Il faudra bien mettre le jour.exe dans le repertoire où tu lance le batch...
DSL c'est string.h...

Répondre à chuka

12

Dikmas, le 29 oct 2008 à 10:23:10

Bon, la sauvegarde se fait. Mais il y a quelques soucis.
Pour que tu comprenne je vais te donner mon architecture

D:\
------backupmysql
-------------menagerie
-------------<emplacement_où_je_voudrais_mes_fichiers_de_sauvegarde.sql>
------jour.exe
------sauv_jours.bat


donc, le fichier "sauv_mercredi" se créé bien, mais directement dans le répertoire "backupmysql". De plus, il lui manque l'extension ".sql". par conséquent, la restauration sera impossible.

J'ai cherché où je pouvais modifier cela dans l'exécutable, mais j'avoue que j'ai un peu du ma

Répondre à Dikmas

13

chuka, le 29 oct 2008 à 10:27:35

Cd\PATH
jour.exe
for /F %%a in (jour.txt) do set jour=sauv_%%a.sql
mysqldump -u root -proot menagerie > menagerie \%JOUR%
del /Q jour.txt

je pense que cela devrait faire l'affaire!!
Dit moi si oui ou non...

Répondre à chuka

14

Dikmas, le 29 oct 2008 à 10:33:59

ça marche.

Mais lors de l'exécution du batch j'ai une erreur :

le chemin spécifié est introuvable.

la sauvegarde se fait correctement et il ne me retourne pas d'erreur dans mon fichier log.

Répondre à Dikmas

15

chuka, le 29 oct 2008 à 10:38:06

@ECHO OFF

@ECHO Vous avez choisis de sauvegarder la base menagerie

d:
cd\backupmysql
jour.exe
for /F %%a in (jour.txt) do set jour=sauv_%%a.sql
mysqldump -u root -proot menagerie > menagerie\%JOUR%
del /Q jour.txt
SET REUSSI=Sauvegarde de menagerie reussi
SET ECHEC=Sauvegarde de menagerie echouee
@if %ERRORLEVEL% EQU 0 echo %REUSSI% le %JOUR% >>log.txt
@if %ERRORLEVEL% GEQ 1 echo %ECHEC% le %JOUR% code erreur : %ERRORLEVEL% >>log.txt

Ton batch ressemble bien à cela?

Répondre à chuka

16

Dikmas, le 29 oct 2008 à 10:44:02

Maintenant oui.
Comme un idiot j'avais oublié de changer le cd\path

j'ai fait quelques tests, notamment pour voir si, lorsqu'il y a une erreur lors de la sauvegarde, celle ci s'inscrit bien dans le fichier "log.txt"
J'ai donc lancé la sauvegarde après avoir mis un nom de base qui ne correspond pas à la mienne. Il me met une erreur comme quoi il trouve pas la table.
Je vais vérifier le fichier de sauvegarde de la table : l'ancien a bien été écrasé par le nouveau, la sauvegarde n'a pas été faite. jusque là, rien d'anormal.
Je vais voir mon fichier de log et la je vois la ligne : Sauvegarde de menagerie reussi le sauv_mercredi.sql
C'est un peu embêtant qu'il me dise qu'elle est réussit alors qu'elle a échouée.

Répondre à Dikmas

17

chuka, le 29 oct 2008 à 10:50:42

D:
cd\backupmysql
SET REUSSI=Sauvegarde de menagerie reussi
SET ECHEC=Sauvegarde de menagerie echouee
jour.exe
for /F %%a in (jour.txt) do set jour=sauv_%%a.sql
mysqldump -u root -proot menagerie > menagerie\%JOUR%
@if %ERRORLEVEL% EQU 0 echo %REUSSI% le %JOUR% %date% %time%>>log.txt
else echo %ECHEC% le %JOUR% %date% %time%code erreur : %ERRORLEVEL% >>log.txt
del /Q jour.txt

essaie cela...j'ai rajouter la date et l'heure pour avoir un peu plus d'info...

Répondre à chuka

18

Dikmas, le 29 oct 2008 à 10:56:40

Donc, lorsque la sauvegarde reussi j'ai droit à la ligne :

auvegarde de menagerie reussi le sauv_mercredi.sql 29/10/2008 10:53:32,95

en revanche, j'ai aussi droit à l'erreur :

'else' n'est pas reconnu en tant que commande interne ou externe, un programme exécutable ou un fichier de commandes.

par conséquent, lorsqu'il y a une erreur, rien ne s'écrit dans le fichier log.txt.

edit :

j'ai remplacé la ligne avec "else" par :

@if %ERRORLEVEL% GEQ 1 echo %ECHEC% le %JOUR% code erreur : %ERRORLEVEL% >> D:\backupmysql\log.txt

et ça fonctionne.

Répondre à Dikmas

19

chuka, le 29 oct 2008 à 11:11:37

Cool!!
Tout marche alors??

Répondre à chuka
Collection CommentÇaMarche.net