编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份

这篇具有很好参考价值的文章主要介绍了编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

 查看数据和数据表

mysql -uroot -p'123456' -e 'show databases'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

 mysql -uroot -p'123456' -e 'show tables from cb_d'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

删除头部Database和数据库自带的表

mysql -uroot -p'123456' -e 'show databases' -N | egrep -v "information_schema|mysql|performance_schema|sys"

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

 编写脚本

#!/bin/bash
#********************************************************************
#Author: cb
#Date: 2023-11-02
#FileName: cbmysql.sh
#Description: The test script
#********************************************************************


#除去系统自带的库以外,再将存在的数据库名分别保存到dbname文件中
mysql -uroot -p'123456' -e 'show databases' -N | egrep -v 'information_schema|mysql|performance_schema|sys' > dbname

# 判断是否有/backup/db目录,没有则创建
[ -d /backup/db ] || mkdir -p /backup/db

#一行一行读取dbname中的库名,然后开始备份数据库,进而分别备份数据库中的表
while read line
do
        #备份数据库
        mysqldump -uroot -p'123456' -B $line | gzip > /backup/db/${line}_$(date +%F).sql.gz

        #分别将数据库中的表名保存到tbname文件中
        mysql -uroot -p'123456' -e "show tables from $line" -N > tbname

        #判断是否有/backup/db/$line目录,没有则创建
        [ -d /backup/db/$line ] || mkdir /backup/db/$line

        #读取tbname中的表名,备份数据表
        while read line2
        do
                #备份数据表
                mysqldump -uroot -p'123456' $line $line2 | gzip > /backup/db/$line/${line2}_$(date +%F).sql.gz
        done < tbname
done < dbname

检查脚本运行备份数据库

tree /backup/db

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

分表分库备份成功

还原检测

删除数据库并查看库

 mysql -uroot -p'123456' -e 'drop database cb_d'
mysql -uroot -p'123456' -e 'show databases'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

开始还原

使用备份的库进行还原,由于是压缩文件,使用压缩还原

gunzip < /backup/db/cb_d_2023-11-02.sql.gz | mysql -uroot -p'123456' -B

查看数据库

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql

 编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份,数据库,mysql文章来源地址https://www.toymoban.com/news/detail-742739.html

到了这里,关于编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • shell脚本-MySQL数据库备份

    确保mysql服务启动 可以通过mysqldump命令来备份数据库 1.mysqldump 命令语法: 使用 mysqldump 命令备份一个数据库的语法格式如下: 使用 mysqldump 命令备份一个数据库中表的语法格式如下: 2.参数: 实例: 先确保数据库服务启动的情况下,创建shell脚本

    2024年02月16日
    浏览(25)
  • 导出docker MySQL中的数据库写一个shell 脚本

    安装命令 mysqldump 编辑脚本内容 export_mysql.sh 执行以下命令给脚本添加执行权限:

    2024年02月21日
    浏览(35)
  • mysql数据库备份(mysqldump)

    1. 备份全部数据库的数据和结构 2. 备份全部数据库的结构(加 -d 参数) 3. 备份全部数据库的数据(加 -t 参数) 4. 备份单个数据库的数据和结构(,数据库名mydb) 5. 备份单个数据库的结构 6. 备份单个数据库的数据 7. 备份多个表的数据和结构(数据,结构的单独备份方法与上同)

    2024年02月07日
    浏览(39)
  • MySQL mysqldump备份数据库(附带实例)

    数据库的主要作用就是对数据进行保存和维护,所以备份数据是数据库管理中最常用的操作。为了防止数据库意外崩溃或硬件损伤而导致的数据丢失,数据库系统提供了备份和恢复策略。 保证数据安全的最重要的一个措施就是定期的对数据库进行备份。这样即使发生了意外,

    2024年02月13日
    浏览(203)
  • mysql,mysqldump数据库导入导出sql文件

    在使用MySQL数据库时,经常需要备份和恢复数据库,通过导出sql文件备份和直接执行sql文件恢复是非常便捷的方式。本篇博客主要介绍如何对MySQL数据库通过cmd命令导出和导入sql文件。 导出sql文件可以使用mysqldump。主要有如下几种操作: ①导出整个数据库 (包括数据库中的数

    2023年04月10日
    浏览(41)
  • Windows下手动、自动备份Mysql数据库(mysqldump)

    (本文实例环境及版本 MySql8.0.13) 1.1 命令行备份 cmd 先进入mysql所在的bin目录下,如:cd D:softwaremysqlmysql-8.0.13-winx64bin mysqldump -u root -p 数据库 [表名1 表名2…] 文件备份路径 如把testdb数据库备份到 D:ydTest.sql 输入密码后回车 mysqldump -u root -p testdb d:ydTest.sql 如果你希望备份是

    2023年04月19日
    浏览(28)
  • shell脚本实现Mysql分库分表备份

    12张图把分库分表讲的明明白白! 阿里面试:我们为什么要分库分表 https://mp.weixin.qq.com/s?__biz=MzU0OTE4MzYzMw==mid=2247547792idx=2sn=91a10823ceab0cb9db26e22783343debchksm=fbb1b26eccc63b784879f90540c8ab1731e635b30e5f4fd41de67f87a4fe055473039206f09dscene=27 4.1.创建三个数据库:compay,jiaowu,goods 4.2.查看数据库及表  

    2024年02月22日
    浏览(37)
  • Windows服务器使用Mysqldump备份MySQL数据库方法

    Windows服务器使用Mysqldump备份MySQL数据库方法 1.进入到MySQL安装目录的bin目录下,进入cmd F:20220601dev_softwaremysql-8.0.11-winx64 2.执行备份命令: 3.导入备份 数据: 4.验证数据表是否备份成功

    2024年02月10日
    浏览(48)
  • 简单shell脚本的编写

    shell脚本就是将命令写入文本中,文本可以被执行。 脚本:本质是一个文件,文件里面存放的是 特定格式的指令,系统可以使用脚本解析器 翻译或解析 指令 并执行(它不需要编译) shell 既是应用程序,又是一种脚本语言(应用程序 解析 脚本语言)。 简单使用 $0 表示当前

    2024年02月10日
    浏览(29)
  • shell 脚本编写

    2023年04月09日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包