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

[经验分享] 实现MySQL分库分表备份的脚本

[复制链接]
发表于 2018-10-1 08:20:38 | 显示全部楼层 |阅读模式
  1)准备测试数据:通过写脚本批量建库建表并插入测试数据。
  [root@aliyun scripts]# cat ceshi.sh
  #/bin/bash
  PATH="/usr/local/mysql/bin:$PATH"                 #定义mysql命令所在路径
  MYUSER=root                                                     #定义数据用户名
  DBPATH=/server/backup                                    #定义数据备份目录
  MYPASS=xiwei1995                                             #定义数据用户密码
  SOCKET=/tmp/mysql.sock                                  #定义数据库sock文件,多实例的指定对应路径
  MYCMD="mysql -u$MYUSER -p$MYPASS "      #定义登录数据库的命令
  for dbname in test2 test3 test4 test5
  do
  $MYCMD -e "create database $dbname"         #批量创建库
  $MYCMD -e "use $dbname;create table test(id int,name varchar(16));insert into test values(1,'testdata');"  #在这些库里面创建表test,并插入测试数据
  done
  2)使用脚本查看测试数据结果:
  [root@aliyun scripts]# cat catceshi.sh
  #/bin/bash
  PATH="/usr/local/mysql/bin:$PATH"                 #定义mysql命令所在路径
  MYUSER=root                                                     #定义数据用户名
  DBPATH=/server/backup                                    #定义数据备份目录
  MYPASS=xiwei1995                                             #定义数据用户密码
  SOCKET=/tmp/mysql.sock                                  #定义数据库sock文件,多实例的指定对应路径
  MYCMD="mysql -u$MYUSER -p$MYPASS "      #定义登录数据库的命令
  for dbname in test2 test3 test4 test5
  do
  echo =============${dbname}.test=============================
  $MYCMD -e "use $dbname;select * from ${dbname}.test;" #批量查看数据
  done
  查看结果如下:
  [root@aliyun scripts]# sh catceshi7.sh
  =============test2.test=============================
  +------+----------+

  |>  +------+----------+
  |    1 | testdata |
  +------+----------+
  =============test3.test=============================
  +------+----------+

  |>  +------+----------+
  |    1 | testdata |
  +------+----------+
  =============test4.test=============================
  +------+----------+

  |>  +------+----------+
  |    1 | testdata |
  +------+----------+
  =============test5.test=============================
  +------+----------+

  |>  +------+----------+
  |    1 | testdata |
  +------+----------+
  3)真正实现MySQL分库分表的脚本
  [root@aliyun scripts]# cat backMySQL.sh
  #/bin/bash
  PATH="/usr/local/mysql/bin:$PATH"                 #定义mysql命令所在路径
  MYUSER=root                                                     #定义数据用户名
  DBPATH=/server/backup                                    #定义数据备份目录
  MYPASS=xiwei1995                                             #定义数据用户密码
  SOCKET=/tmp/mysql.sock                                  #定义数据库sock文件,多实例的指定对应路径
  MYCMD="mysql -u$MYUSER -p$MYPASS "      #定义登录数据库的命令
  MYDUMP="mysqldump -u$MYUSER -p$MYPASS"  #备份数据库的命令
  [ ! -d "$DBPATH" ] && mkdir $DBPATH
  for dbname in `$MYCMD -e "show databases;"|sed '1,2d'|egrep -v "mysql|schema"` #登录数据库获取数据库里的所有数据库名
  do
  mkdir $DBPATH/${dbname}_$(date +%F) -p  #创建对应目录。
  for table in `$MYCMD -e "show tables from $dbname;"|sed '1d'` #内层循环,获取每个库里的所有表,然后进入循环。
  do
  $MYDUMP $dbname $table|gzip >$DBPATH/${dbname}_$(date +%F)/${dbname}_${table}.sql.gz  #备份指定的库内的表到指定目录下,并以库表名字命名备份的名字。
  done
  done
  执行脚本结果如下:
  [root@aliyun scripts]# rm -f /server/backup/*
  [root@aliyun scripts]# sh backMySQL.sh
  [root@aliyun scripts]# tree /server/backup/
  /server/backup/
  |-- test2_2018-05-12
  |   `-- test2_test.sql.gz
  |-- test3_2018-05-12
  |   `-- test3_test.sql.gz
  |-- test4_2018-05-12
  |   `-- test4_test.sql.gz
  |-- test5_2018-05-12
  |   `-- test5_test.sql.gz
  到这里,就表示脚本成功执行了


运维网声明 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.iyunv.com/thread-606934-1-1.html 上篇帖子: Mysql错误代码大全 下篇帖子: navicat for mysql 客户端操作mysql非常慢问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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