设为首页 收藏本站
查看: 1098|回复: 0

[经验分享] Mysql备份脚本—mysqldump

[复制链接]

尚未签到

发表于 2018-10-8 09:30:22 | 显示全部楼层 |阅读模式
#!/bin/bash  
#Script_Name: mysql_backup.
sh  
#Author: 蜷缩的小蜗牛
  
#Site:  www.along.party
  
#Version: V0.
1  
#Purpose: Mysql Backup
  
#Create_Time:
2017/07/25  

  

  
DB_NAME
=$1  
BASE_PATH
=`dirname $0`  
log_file
='mysql_backup.log'  

  
LOG()
  
{
time=`date "+%Y-%m-%d %H:%M:%S"`echo "[${time}] $*"  echo "[${time}] $*">>${BASE_PATH}/${log_file}
  
}
  

  
WARN_LOG()
  
{
  time=`date "+%Y-%m-%d %H:%M:%S"`
  echo -e "\033[33m[${time}]WARNING: $*\033[0m"
  echo "[${time}] $*">>${BASE_PATH}/${log_file}
  
}
  
ERR_LOG()
  
{
  time=`date "+%Y-%m-%d %H:%M:%S"`
  echo -e "\033[31m[${time}]ERROR: $*\033[0m"
  echo "[${time}] $*">>${BASE_PATH}/${log_file}
  
}
  
SUCC_LOG()
  
{
  time=`date "+%Y-%m-%d %H:%M:%S"`
  echo -e "\033[32m[${time}]SUCCESS: $*\033[0m"
  echo "[${time}] $*">>${BASE_PATH}/${log_file}
  
}
  

  
HELP()
  
{
  echo "USE: bash ${0} ALL | DATABASE_NAME"
  echo -e "\tALL : 备份所有数据库!"
  echo -e "\tDATABASE_NAME : 数据库名称!!"
  
}
  

  

  
##全库备份
  
ALL_BACKUP()
  
{
  startTime=`date +%s`
  LOG "全库备份开始"
  LOG "mysqldump -u${DB_USER} -p -h${DB_HOST} -P${DB_PORT}    --all-databases --single-transaction  >${BAK_PATH}/${DB_HOST}-ALL_DATABASE-${NOW_TIME}"
  mysqldump -u${DB_USER} -p${DB_PASS} -h${DB_HOST} -P${DB_PORT}    --all-databases --single-transaction \
  >${BAK_PATH}/${DB_HOST}-ALL_DATABASE-${NOW_TIME} 2>.warn.log
  if [ $? -eq 0 ];then
  SUCC_LOG
  cd ${BAK_PATH}
  tar -zcvf ${DB_HOST}-ALL_DATABASE-${NOW_TIME}.tar.gz ${DB_HOST}-ALL_DATABASE-${NOW_TIME}
  endTime=`date +%s`
  ((outTime=(${endTime}-${startTime})))
  LOG "全库备份成功,用时[$outTime]秒"
  rm -rf ALL_DATABASE-${NOW_TIME}
  else
  ERR_LOG "全库备份异常,请查看${log_file}日志文件"
  ERR_LOG `head -10 .warn.log`
  rm -rf .warn.log
  fi
  
}
  

  
##备份单个库
  
DB_BACKUP()
  
{
  startTime=`date +%s`
  

  LOG "数据库[${DB_NAME}]备份开始"
  LOG "mysqldump -u${DB_USER} -p -h${DB_HOST} -P${DB_PORT} ${DB_NAME}   >${BAK_PATH}/${DB_HOST}-${DB_NAME}-${NOW_TIME}"
  mysqldump -u${DB_USER} -p${DB_PASS} -h${DB_HOST} -P${DB_PORT} ${DB_NAME}   >${BAK_PATH}/${DB_HOST}-${DB_NAME}-${NOW_TIME}
  if [ $? -eq 0 ];then
  SUCC_LOG
  cd ${BAK_PATH}
  tar -zcvf ${DB_HOST}-${DB_NAME}-${NOW_TIME}.tar.gz ${DB_HOST}-${DB_NAME}-${NOW_TIME}
  endTime=`date +%s`
  ((outTime=(${endTime}-${startTime})))
  LOG "数据库[${DB_NAME}]备份成功,用时[$outTime]秒"
  rm -rf ${DB_NAME}-${NOW_TIME}
  else
  ERR_LOG "数据库[${DB_NAME}]备份失败"
  ERR_LOG `head -10 .warn.log`
  rm -rf .warn.log
  fi
  
}
  

  

  

  
main()
  
{
  if [ -f "${BASE_PATH}/config.ini" ];then
  source ${BASE_PATH}/config.ini
  else
  ERR_LOG "配置文件${BASE_PATH}/config.ini不存在"
  exit 1
  fi
  if [ -z $DB_NAME ];then
  HELP
  elif [ $DB_NAME == "ALL" ];then
  ALL_BACKUP
  

  else
  DB_BACKUP
  fi
  
}
  

  
main



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-616101-1-1.html 上篇帖子: mysql 客户端工具参数详解 下篇帖子: MySQL中too many connections问题解决
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表