Резервное копирование

Надеемся, что все в курсе, что администраторы делятся на тех кто делает бекапы и безработных тех кто уже делает? Также напоминаем, что локальное хранение резервных копий зачастую эквивалентно их отсутствию. Если у вас нету времени или возможности настраивать нормальную систему резервного копирования, можете воспользоваться следующим скриптом.

backupalka.sh
#!/bin/sh
 
# directory to store local backups
BACKUP_DIR="/home/backups/"
 
# max backups store age in days
MAX_AGE=30
 
# dirs which will be packed during backup 
SYSTEM_DIRS="/etc /usr/local/etc /usr/local/www/apache22/data /var/named/etc"
 
# mysqldump path
MYSQLDUMP="/usr/local/bin/mysqldump"
 
# mysql user login
MYSQL_USER="root"
 
# mysql password
MYSQL_PASSWORD="newpassword"
 
# mysql database host
MYSQL_HOST="localhost"
 
# ftp upload of backup archive, using ncftp
# you can install it with following command: fetch ftp://ftp.ncftp.com/ncftp/ncftp-3.2.5-src.tar.gz && tar zxvf ncftp-3.2.5-src.tar.gz && cd ncftp-3.2.5 && ./configure && make && make install
FTP_UPLOAD="NO"
 
# ftp backup remote host
FTP_HOST="backups.isp"
 
# ftp user login
FTP_LOGIN="myftplogin"
# ftp user password
FTP_PASSWORD="myftppassword"
 
#remote directory to upload backups (must exists)
FTP_REMOTE_PATH="/home/backups/billingserver/"
 
##############################################################
DATE=`date +%Y%m%d`
 
cd $BACKUP_DIR; mkdir $DATE; chmod 777 $DATE; cd $DATE;
 
tar cf - $SYSTEM_DIRS | gzip > system.tar.gz
mkdir sql; chmod 777 sql; cd sql;
${MYSQLDUMP} --opt --skip-lock-tables --single-transaction -h ${MYSQL_HOST} -p${MYSQL_PASSWORD} -u ${MYSQL_USER} --all-databases | gzip > mysql.sql.gz
 
##############################################################
cd $BACKUP_DIR
for i in *; do
  AGE=`echo $DATE-$i|bc`
  if [ $AGE -gt 69 ]; then
    AGE=`echo $AGE-69|bc`
  fi
  if [ $AGE -gt $MAX_AGE ]; then
    rm -rf $i
  fi
 done
 
 
case $FTP_UPLOAD in 
YES)
/usr/local/bin/ncftpput -R -v  -u ${FTP_LOGIN} -p ${FTP_PASSWORD}  ${FTP_HOST} ${FTP_REMOTE_PATH} ${BACKUP_DIR}${DATE} 
echo "FTP upload finished";;
NO)
echo "No FTP upload enabled";;
esac
backupalka.txt · Последние изменения: 2013/02/21 00:56 — nightfly
 
За исключением случаев, когда указано иное, содержимое этой вики предоставляется на условиях следующей лицензии: CC Attribution-Share Alike 3.0 Unported
Recent changes RSS feed Donate Powered by PHP Valid XHTML 1.0 Valid CSS Driven by DokuWiki