db_bk.sh 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/bin/bash
  2. # Author: yeho <lj2007331 AT gmail.com>
  3. # BLOG: https://blog.linuxeye.cn
  4. #
  5. # Notes: OneinStack for CentOS/RadHat 6+ Debian 7+ and Ubuntu 12+
  6. #
  7. # Project home page:
  8. # https://oneinstack.com
  9. # https://github.com/lj2007331/oneinstack
  10. . ../options.conf
  11. . ../include/check_dir.sh
  12. DBname=$1
  13. LogFile=${backup_dir}/db.log
  14. DumpFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d_%H).sql
  15. NewFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d_%H).tgz
  16. OldFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d --date="$expired_days days ago")*.tgz
  17. [ ! -e "${backup_dir}" ] && mkdir -p ${backup_dir}
  18. DB_tmp=`${db_install_dir}/bin/mysql -uroot -p$dbrootpwd -e "show databases\G" | grep $DBname`
  19. [ -z "$DB_tmp" ] && { echo "[$DBname] not exist" >> $LogFile ; exit 1 ; }
  20. if [ -n "`ls $OldFile 2>/dev/null`" ]; then
  21. /bin/rm -f $OldFile
  22. echo "[$OldFile] Delete Old File Success" >> $LogFile
  23. else
  24. echo "[$OldFile] Delete Old Backup File" >> $LogFile
  25. fi
  26. if [ -e "$NewFile" ]; then
  27. echo "[$NewFile] The Backup File is exists, Can't Backup" >> $LogFile
  28. else
  29. ${db_install_dir}/bin/mysqldump -uroot -p$dbrootpwd --databases $DBname > $DumpFile
  30. cd ${backup_dir}
  31. tar czf $NewFile ${DumpFile##*/} >> $LogFile 2>&1
  32. echo "[$NewFile] Backup success ">> $LogFile
  33. /bin/rm -f $DumpFile
  34. fi