当前位置: 首页 > article >正文

shell脚本实战案例---数据库的备份

目录

1.环境准备

2.数据库的分库分表备份

2.1 分库备份

2.2 分表备份

2.3 分库分表备份


通过此次shell脚本实战案例,我们将学习和了解到如何利用shell脚本实现数据库的分库分表备份。

1.环境准备

要实现数据库的备份,首先我们应该要有数据库的环境,以及需要备份的数据

在这里我们就使用rpm包的方式安装数据库

【1】先从官网下载rpm安装包,上传至服务器

https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.14-1.el7.x86_64.rpm-bundle.tar

【2】解压

 [root@localhost ~]# tar -xf mysql-5.7.14-1.el7.x86_64.rpm-bundle.tar

【3】安装

[root@localhost ~]# yum install -y mysql-community-server-5.7.14-1.el7.x86_64.rpm 
# 由信息得知,下面几个都得安装  
[root@localhost ~]# yum install -y mysql-community-server-5.7.14-1.el7.x86_64.rpm mysql-community-libs-5.7.14-1.el7.x86_64.rpm mysql-community-client-5.7.14-1.el7.x86_64.rpm mysql-community-common-5.7.14-1.el7.x86_64.rpm  
# 由于之前安装了别的数据库,所以冲突了,需要卸载下面这个  
[root@localhost ~]# yum remove mariadb-libs  
# 重新安装上面的

【4】启动

[root@node11 ~]# systemctl enable --now mysqld

【5】查看

[root@node11 ~]# ps -ef | grep mysqld
[root@node11 ~]# netstat -lnupt | grep 3306

【6】进入数据库,修改密码

[root@node11 ~]# grep password /var/log/mysqld.log    # 查看密码
[root@node11 ~]# mysql -uroot -p    # 登录数据库
Enter password: 
mysql> alter user root@localhost identified by 'MySQL@123';    # 修改密码
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like '%char%';    # 查看字符集
# 永久修改如下:
mysql> \q
Bye
[root@node11 ~]# vim /etc/my.cnf
[mysqld]
character-set-server = utf8
[root@node11 ~]# systemctl restart mysqld    # 重启数据库服务

 【7】创建数据库,创建表,导入数据

[root@node11 ~]# mysql -uroot -p    进入数据库
Enter password: 
# 创建数据库db1和其中的两张表:
mysql> create database db1;
mysql> use db1;
create table dept (dept1 int ,dept_name varchar(11));
insert into dept values
(101,'财务'),
(102,'销售'),
(103,'IT技术'),
(104,'行政');

create table emp (sid int ,name varchar(11),age int,worktime_start date,incoming int,dept2 int);
insert into emp values
(1789,'张三',35,'1980/1/1',4000,101),
(1674,'李四',32,'1983/4/1',3500,101),
(1776,'王五',24,'1990/7/1',2000,101),
(1568,'赵六',57,'1970/10/11',7500,102),
(1564,'荣七',64,'1963/10/11',8500,102),
(1879,'牛八',55,'1971/10/20',7300,103);

# 创建数据库db2和其中的两张表
mysql> create database db2;
mysql> use db2;
CREATE TABLE `t_dept` (
 `id` INT(11) NOT NULL AUTO_INCREMENT,
 `deptName` VARCHAR(30) DEFAULT NULL,
 `address` VARCHAR(40) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO t_dept(deptName,address) VALUES('华山','华山');
INSERT INTO t_dept(deptName,address) VALUES('丐帮','洛阳');
INSERT INTO t_dept(deptName,address) VALUES('峨眉','峨眉山');
INSERT INTO t_dept(deptName,address) VALUES('武当','武当山');
INSERT INTO t_dept(deptName,address) VALUES('明教','光明顶');
INSERT INTO t_dept(deptName,address) VALUES('少林','少林寺');


CREATE TABLE `t_emp` (
 `id` INT(11) NOT NULL AUTO_INCREMENT,
 `name` VARCHAR(20) DEFAULT NULL,
  `age` INT(3) DEFAULT NULL,
 `deptId` INT(11) DEFAULT NULL,
empno int  not null,
 PRIMARY KEY (`id`),
 KEY `idx_dept_id` (`deptId`)
 #CONSTRAINT `fk_dept_id` FOREIGN KEY (`deptId`) REFERENCES `t_dept` (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('风清扬',90,1,100001);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('岳不群',50,1,100002);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('令狐冲',24,1,100003);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('洪七公',70,2,100004);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('乔峰',35,2,100005);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('灭绝师太',70,3,100006);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('周芷若',20,3,100007);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('张三丰',100,4,100008);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('张无忌',25,5,100009);
INSERT INTO t_emp(NAME,age,deptId,empno) VALUES('韦小宝',18,null,100010);

 最后查看一下,确保数据无误。

2.数据库的分库分表备份

此次实验,我们利用自带的mysqldump工具,实现数据库的分库分表备份

[root@node11 ~]# mkdir -p /server/scripts        # 脚本路径
[root@node11 ~]# mkdir -p /backup/mysql        # 数据库备份路径

2.1 分库备份

【1】首先我们获取数据库列表

[root@node11 ~]# mysql --help | grep skip    # -N选项:跳过列名
  -N, --skip-column-names 
                      (Defaults to on; use --skip-reconnect to disable.)
                      (Defaults to on; use --skip-ssl to disable.)

[root@node11 ~]# mysql -uroot -p'MySQL@123' -N -e 'show databases' | egrep -v "information_schema|mysql|performance_schema|sys"

【2】然后我们实现循环遍历数据库

[root@node11 scripts]# vim datab_1.sh
#!/bin/bash

for db in $DBS
do
    echo 备份$db
done:

【3】其次备份数据库语句的实现

[root@node11 scripts]# mysqldump -uroot -p'MySQL@123' -B db1 > /backup/mysql/db1_$(date +%F).sql
# 注意:-B作用:创建数据库和切换数据库,不加-B时,在恢复时必须手动创建数据库
[root@node11 scripts]# ll /backup/mysql/
-rw-r--r-- 1 root root 2940 Oct 29 03:36 db1_2023-10-29.sql

【4】最后分库备份的参考代码

刚才备份的SQL语句全部删掉,进行测试

上面的分步骤中,数据库固定,下面的脚本中要进行修改

[root@node11 scripts]# vim datab_2.sh 
#!/bin/bash

# define var
OPT="-uroot -pMySQL@123"
EX_DB="information_schema|mysql|performance_schema|sys"
DBS=$(mysql ${OPT} -N -e 'show databases' | egrep -v ${EX_DB})
BAK_DIR=/backup/mysql


[ -d $BAK_DIR ] || mkdir -p $BAK_DIR
# main program
for db in $DBS
do
    mysqldump ${OPT} -B $db > ${BAK_DIR}/${db}_$(date +%F).sql
done
[root@node11 scripts]# sh  datab_2.sh     # 执行脚本
-n:检测语法是否有错误
-x:跟踪脚本,发现错误

2.2 分表备份

【1】首先我们获取数据库中表

[root@node11 scripts]# mysql -uroot -pMySQL@123 -N -e 'show tables from db1'

【2】然后我们实现循环遍历数据库中的表

[root@node11 scripts]# vim tab_1.sh
#!/bin/bash

for tab in $TABS
do
    echo 备份表$tab
done

【3】其次备份数据库中的表的语句

[root@node11 mysql]# mkdir db1
[root@node11 scripts]# mysqldump -uroot -pMySQL@123 db1 emp > /backup/mysql/db1/db1_emp_$(date +%F).sql

【4】最后分库备份的参考代码

刚才备份的SQL语句全部删掉,进行测试

上面的分步骤中,数据库固定,下面的脚本中要进行修改

[root@node11 scripts]# vim tab_2.sh 
#!/bin/bash

# define var
OPT="-uroot -pMySQL@123"
DBS=db1
TABS=$(mysql ${OPT} -N -e "show tables from ${DBS}")
BAK_DIR=/backup/mysql/db1

[ -d $BAK_DIR ] || mkdir -p $BAK_DIR
# main program
for tab in $TABS
do
    mysqldump ${OPT} $DBS $tab > ${BAK_DIR}/${DBS}_${tab}_$(date +%F).sql
done
[root@node11 scripts]# sh tab_2.sh

2.3 分库分表备份

[root@node11 scripts]# vim all.sh
#!/bin/bash

# define var
OPT="-uroot -pMySQL@123"
EX_DB="information_schema|mysql|performance_schema|sys"
BAK_DIR=/backup/mysql

DBS=$(mysql ${OPT} -N -e 'show databases' | egrep -v ${EX_DB})

# main program
for db in $DBS
do
    [ -d ${BAK_DIR}/$db ] || mkdir -p ${BAK_DIR}/$db
    mysqldump ${OPT} -B $db > ${BAK_DIR}/${db}/${db}_$(date +%F).sql
    TABS=$(mysql ${OPT} -N -e "show tables from $db")

    for tab in $TABS
    do
        mysqldump ${OPT} $db $tab > ${BAK_DIR}/${db}/${db}_${tab}_$(date +%F).sql
    done
done

后续可以结合计划任务进行数据库的备份。


http://www.kler.cn/a/107974.html

相关文章:

  • fast-crud select下拉框 实现多选功能及下拉框数据动态获取(通过接口获取)
  • 慧集通(DataLinkX)iPaaS集成平台-数据流程之流程透明化调试功能简介
  • Sql 创建用户
  • 你好,2025!JumpServer开启新十年
  • STM32供电参考设计
  • 深入Android架构(从线程到AIDL)_18 SurfaceView的UI多线程02
  • 【C++】STL容器——探究不同 [ 迭代器 ] 种类&在STL中的使用方式(15)
  • html5怎么实现语音搜索
  • Android系统的特性
  • RPC远程调用加密方法获取返回值
  • 线扫相机DALSA--常见问题一:软件安装顺序
  • 【JavaEE】HTTP协议
  • Vue3.0插槽
  • Windows相关知识
  • 磁盘的结构(磁道,扇区,盘面,柱面,物理地址)
  • TypeScript - 字符串的字面类型
  • Android---StartActivity启动过程
  • react高阶成分(HOC)例子效果
  • 如何在vscode中添加less插件
  • 【菜菜研科研小BUG记录】【Latex写作方面1】不定期更新
  • 【开源】基于SpringBoot的计算机机房作业管理系统的设计和实现
  • 2011-2021年“第四期”数字普惠金融与上市公司匹配(根据城市匹配)/上市公司数字普惠金融指数匹配数据
  • Flutter笔记:完全基于Flutter绘图技术绘制一个精美的Dash图标(下)
  • [微信小程序踩坑]微信小程序editor富文本组件渲染字符串时,内部图片超出大小导致无法正常渲染或回显(数据传输长度为 3458 KB,存在有性能问题!)
  • 处理大数据的基础架构,OLTP和OLAP的区别,数据库与Hadoop、Spark、Hive和Flink大数据技术
  • 策略路由和路由策略