Difference between revisions of "Backup scripts"
Jump to navigation
Jump to search
Rafahsolis (talk | contribs) |
Rafahsolis (talk | contribs) |
||
| Line 5: | Line 5: | ||
The script should be in the MediaWiki installation (where your [[LocalSettings.php]] is stored as well). | The script should be in the MediaWiki installation (where your [[LocalSettings.php]] is stored as well). | ||
== backup.sh == | == backup.sh == | ||
| − | < | + | <source lang="bash"> |
#!/bin/bash | #!/bin/bash | ||
FNAME=TS=RHSWiki`date +%d-%m-%Y` | FNAME=TS=RHSWiki`date +%d-%m-%Y` | ||
| Line 11: | Line 11: | ||
zip -r ./backup/${FNAME}.zip images/ ${FNAME}.sql LocalSettings.php extensions/ | zip -r ./backup/${FNAME}.zip images/ ${FNAME}.sql LocalSettings.php extensions/ | ||
rm ${FNAME}.sql | rm ${FNAME}.sql | ||
| − | </ | + | </source> |
Bonus (not required): | Bonus (not required): | ||
| − | < | + | <source lang="bash"> |
# careful here .. if this fails you'll delete files from the current directory instead. | # careful here .. if this fails you'll delete files from the current directory instead. | ||
# Some checking might be in order, especially if you run this script from somewhere else | # Some checking might be in order, especially if you run this script from somewhere else | ||
| Line 32: | Line 32: | ||
file_count=`ls | wc -l` | file_count=`ls | wc -l` | ||
done | done | ||
| − | </ | + | </source> |
[http://www.mediawiki.org/wiki/User:Flominator/Backup_MW Source] | [http://www.mediawiki.org/wiki/User:Flominator/Backup_MW Source] | ||
Revision as of 03:32, 26 March 2015
Wikimedia
First add the following line to LocalSetings.php
$wgReadOnly = 'Dumping Database, Access will be restored shortly';
Delete this line after the backup.
The script should be in the MediaWiki installation (where your LocalSettings.php is stored as well).
backup.sh
#!/bin/bash
FNAME=TS=RHSWiki`date +%d-%m-%Y`
mysqldump --database DATABASE_NAME -u USERNAME -pPASSWORD --add-drop-table -B > ${FNAME}.sql
zip -r ./backup/${FNAME}.zip images/ ${FNAME}.sql LocalSettings.php extensions/
rm ${FNAME}.sql
Bonus (not required):
# careful here .. if this fails you'll delete files from the current directory instead.
# Some checking might be in order, especially if you run this script from somewhere else
cd backup
#Count files in directory (hidden files (filename starts with a dot) are ignored)
file_count=`ls | wc -l`
#Do until there are more than or equal 6 files present
while [ $file_count -ge 6 ]
do
#you can save deleted filenames in variable (e.g. for deleting files also in backup directory)
#not recommended for filenames with space(s)
del_files="${del_files} `ls | head -n 1`"
#Delete alphabetically oldest file (ls sort by name is default)
rm `ls | head -n 1`
#Count files again
file_count=`ls | wc -l`
done