工作中,往往数据库备份是件非常重要的事情,毕竟数据就是金钱,就是生命!废话不多,下面介绍一下:如何实现对MySQL数据库进行分库备份(shell脚本)

Mysq数据库dump备份/还原语法:

mysqldump -u 用户名 –p 数据库名 > 导出的文件名;

mysqldump -u 用户名 –p 数据库名 < 导入的文件名;

首先,我们需要知道是备份全库还是部分库;

其次,我们需要获取到需要备份的库名列表;

最后,编写脚本实现数据备份。

分库备份:

1、查看当前环境是否启动了MySQL服务,如果没启动,便启动该服务:

2、获取分库备份的库名列表:

登录MySQL数据库两种方式:sock方式和tcp/ip方式,详情https://my.oschina.net/zjllovecode/blog/1617755

我们以sock方式登录MySQL获取库名列表:

3、编写备份脚本:

[root@bqh-118 scripts]# vim mysqldb.sh
#!/bin/sh
# ******************************************************
# Author : a?锦衣卫
# Last modified: 2019-05-18 13:25
# Email : 1147076062@qq.com
# blog : https://www.cnblogs.com/su-root
# Filename : mysqldb.sh
# Description : mysql_dmup
# ******************************************************
user=root #用户名
pass=123456 #密码
socket=/tmp/mysql.sock #登录方式
backfile=/server/backup #备份路径
[ ! -d $backfile ] && mkdir -p $backfile #判断是否有备份路径
cmd="mysql -u$user -p$pass -S $socket" #登录数据库
dump="mysqldump -u$user -p$pass -S $socket -B -X -F -R" #mysqldump备份参数
dblist=`$cmd -e "show databases;"|sed 1d|egrep -v "_schema|mysql"` #获取库名列表
for db_name in $dblist #for循环备份库列表
do
$dump $db_name|gzip >/server/backup/${db_name}_$(date +%F).sql.gz #库名+时间备份打包至指定路径下
done

执行脚本:

ok,分库备份success!

下面我们介绍一下分库分表备份:

首先,我们需要获取到需要备份的库名列表及表名列表;然后,编写脚本实现数据备份。

ok,库名及表面获取了,接下来我们在已有的脚本基础上稍作修改(加个表名循环即可)

[root@bqh-118 scripts]# vim mysqldb1.sh
#!/bin/sh
# ******************************************************
# Author : a?锦衣卫
# Last modified: 2019-05-18 13:25
# Email : 1147076062@qq.com
# blog : https://www.cnblogs.com/su-root
# Filename : mysqldb.sh
# Description : mysql_dmup_fk
# ******************************************************
user=root #用户名
pass=123456 #密码
socket=/tmp/mysql.sock #登录方式
backfile=/server/backup #备份路径
[ ! -d $backfile ] && mkdir -p $backfile #判断是否有备份路径
cmd="mysql -u$user -p$pass -S $socket" #登录数据库
dump="mysqldump -u$user -p$pass -S $socket -X -F -R" #mysqldump备份参数
dblist=`$cmd -e "show databases;"|sed 1d|egrep 'bqh|jyw'` #获取库名列表
for db_name in $dblist #for循环备份库列表
do
tablest=`$cmd -e "show tables from $db_name;"|sed 1d` #获取库中表名
for tname in $tablest #for循环备份库中表名列表
do
mkdir -p $backfile/$db_name #创建库文件
$dump $db_name $tname|gzip >$backfile/$db_name/${tname}_$(date +%F).sql.gz
#库名+表名+时间备份打包至指定路径下
done
done

执行脚本:

ok,分库分表备份success!

实现对MySQL数据库进行分库/分表备份(shell脚本)的更多相关文章

  1. MyCat:对MySQL数据库进行分库分表

    本篇前提: mycat配置正确,且能正常启动. 1.schema.xml <table>标签: dataNode -- 分片节点指定(取值:dataNode中的name属性值) rule ...

  2. shell脚本,对MySQL数据库进行分库加分表备份

    [root@localhost wyb]# cat table_backup.sh #!/bin/bash flag= user=root pass=test mysql -u$user -p&quo ...

  3. 分享一个MySQL分库分表备份脚本(原)

    分享一个MySQL分库备份脚本(原) 开发思路: 1.路径:规定备份到什么位置,把路径(先判断是否存在,不存在创建一个目录)先定义好,我的路径:/mysql/backup,每个备份用压缩提升效率,带上 ...

  4. mysql数据库为什么要分表和分区?

    一般下载的源码都带了MySQL数据库的,做个真正意义上的网站没数据库肯定不行. 数据库主要存放用户信息(注册用户名密码,分组,等级等),配置信息(管理权限配置,模板配置等),内容链接(html ,图片 ...

  5. Mysql中的分库分表

    mysql中的分库分表分库:减少并发问题分表:降低了分布式事务分表 1.垂直分表 把其中的不常用的基础信息提取出来,放到一个表中通过id进行关联.降低表的大小来控制性能,但是这种方式没有解决高数据量带 ...

  6. Mycat安装并实现mysql读写分离,分库分表

    Mycat安装并实现mysql读写分离,分库分表 一.安装Mycat 1.1 创建文件夹 1.2 下载 二.mycat具体配置 2.1 server.xml 2.2 schema.xml 2.3 se ...

  7. Docker安装Mycat并实现mysql读写分离,分库分表

    Docker安装Mycat并实现mysql读写分离,分库分表 一.拉取mycat镜像 二.准备挂载的配置文件 2.1 创建文件夹并添加配置文件 2.1.1 server.xml 2.1.2 serve ...

  8. MySQL分库分表备份脚本

    MySQL分库备份脚本 #脚本详细内容 [root@db02 scripts]# cat /server/scripts/Store_backup.sh #!/bin/sh MYUSER=root M ...

  9. MySQL纯透明的分库分表技术还没有

    MySQL纯透明的分库分表技术还没有  种树人./oneproxy --proxy-address=:3307 --admin-username=admin --admin-password=D033 ...

随机推荐

  1. CentOS7下yum安装Redis

    (1).Redis概述 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value(键值型)数据库(非关系型数据库),并提供多种语言的API. Redi ...

  2. VS2010配置OpenGL开发环境(转)

    OpenGL(Open Graphics Library)是一个跨编程语言.跨平台的专业图形程序接口.OpenGL是SGI公司开发的一套计算机图形处理系统,是图形硬件的软件接口,任何一个OpenGL应 ...

  3. DevExpress v18.1 下载和教程文档

    http://www.zdfans.com/html/18682.html 教程文档 https://blog.csdn.net/AABBbaby/article/details/81094482 下 ...

  4. Swift4.0复习访问控制与作用域

    1.访问等级: open: 可以继承,可以重写. public: “public 访问等级能用于修饰所有文件作用域的函数.对象.协议.枚举.结构体.类以及各种类型中的属性与方法.用 public 所修 ...

  5. qbittorrent搜索在线插件

    https://raw.githubusercontent.com/khensolomon/leyts/master/yts.py https://raw.githubusercontent.com/ ...

  6. 性能测试监控:Jmeter+Collectd+Influxdb+Grafana

    系统性能指标图示例: 采集数据(collectd)-> 存储数据(influxdb) -> 显示数据(grafana) InfluxDB 是 Go 语言开发的一个开源分布式时序数据库,非常 ...

  7. Eclipse使用JDBC方式连接SQLServer2017

    这篇博客写的比较详细了,图文并茂: https://blog.csdn.net/rebekahq/article/details/78691343 这里补充一些可能会遇到的问题: 1.与博客中不同之处 ...

  8. MongoDB 空间定位(点) 与 距离检索

    转自: http://blog.csdn.net/flamingsky007/article/details/39208837 基于 MongoDB 2.6 GeoJSON 格式 { "ty ...

  9. 快速搭建ssh项目

    环境:oracle11g.myeclipse2014 首先在web项目中添加spring框架 现在已经添加完spring框架了 然后我们开始添加Hibernate框架 到这一步Hibernate框架就 ...

  10. Git操作入门

    生成ssh key: ​ ssh-keygen -t rsa -C "lkt@temp.com" ​ 按三次回车,最后在.ssh文件夹下得到id_rsa和id_rsa.pub两个文 ...