NDB Cluster 存储引擎物理备份
NDB Cluster 存储引擎物理备份
NDB Cluster 存储引擎也是一款事务性存储引擎,和Innodb 一样也有redo 日志。NDB
Cluter 存储引擎自己提供了备份功能,可以通过相关的命令实现。当然,停机冷备的方法
也是有效的。
在线联机备份步骤如下:
1、连接上管理服务器;
2、在管理节点上面执行“START BACKUP” 命令;
3、在管理节点上发出备份指令之后,管理节点会通知所有数据节点开始进行备份,并
反馈通知结果。
4、管理节点在通知发出备份指令之前会生成一个备份号来唯一定位这次备份所产生
的备份集。当各数据节点收到备份指令之后,就会开始进行备份操作。
5、当所有数据节点都完成备份之后,管理节点才会反馈“备份完成”的信息给客户端。
由于NDB Cluster 的备份,备份指令是从管理节点发起,且并不会等待备份完成就会
返回,所以也没办法直接通过“Ctrl + c” 或者其他方式来中断备份进程,所以NDB
Cluster 提供了相应的命令来中断当前正在进行的备份操作,如下:
1、登录管理节点
2、执行“ABORT BACKUP backup_id”,命令中的backup_id 即之前发起备份命令的
时候所产生的备份号。
3、管理结带你上会用消息“放弃指示的备份backup_id”确认放弃请求,注意,则时
候其实并没有收到数据节点对请求的实际回应。
4、然后管理节点才会将中断备份的指令发送到所有数据节点上面,然后当各个数据节
点都中断备份并删除了当前产生的备份文件之后,才会返回“备份backup_id 因*
**而放弃”。至此,中断备份操作完成。
通过NDB Cluster 存储引擎自己的备份命令来进行备份之后,会将前面所提到的三种
文件存放在参与备份的节点上面,且被存放在三个不同的文件中,类似如下:
BACKUP-backup_id.node_id.ctl,内容包含相关的控制信息和元数据的控制文件。每个
节点均会将相同的表定义(对于Cluster 中的所有表)保存在自己的该文件中。
BACKUP-backup_id-n.node_id.data,数据备份文件,被分成多个不同的片段来保存,
在备份过程中,不同的节点将保存不同的备份数据所产生的片段,每个节点保存的文件都会
有信息指明数据所属表的部分,且在备份片段文件最后还包含了最后的校验信息,以确保备
份能够正确恢复。
BACKUP-backup_id.node_id.log,事务日志备份文件中仅包含已提交事务的相关信息,
且仅保存已在备份中保存的表上的事务,各个阶段所保存的日志信息也不一样,因为仅仅针
对各节点所包含的数据记录相关的日志信息。
上面的备份文件命名规则中,backup_id 是指备份号,不同的备份集会针对有一个不
同的备份号,node_id 则是指明该备份文件属于哪个数据节点,而在数据文件的备份文件中
的n 则是指明片段号。
恢复的时候必须要将备份集中文件恢复到对应的数据节点之上,否则无法正确完成恢
复过程。
通过NDB Cluster 所提供的备份命令来生成的备份集,需要使用专用的备份恢复软
件ndb_restore 来进行。ndb_restore 软件将从备份集中读取出备份相关的控制信息,而
且ndb_restore 软件必须在单独的数据节点上面分别进行。所以当初备份进行过程中有多
少数据节点,现在就需要运行多少次ndb_restore。而且,首次通过ndb_restore 来进行
恢复的话,还必须恢复元数据,也就是会重建所有的数据库和表。
数据库性能优化:
商业需求合理化,
系统架构最优化,
逻辑实现精简化,
硬件设施理性化。
ssh sddxwins@192.168.1.2 ~/toolbar_stat/shell/disk_warning_v3.sh
select distinct mdn from
NDB Cluster 存储引擎物理备份的更多相关文章
- 第 3 章 MySQL 存储引擎简介
第 3 章 MySQL 存储引擎简介 前言 3.1 MySQL 存储引擎概述 MyISAM 存储引擎是 MySQL 默认的存储引擎,也是目前 MySQL 使用最为广泛的存储引擎之一.他的前身就是我们在 ...
- MySql(十一):MySQL性能调优——常用存储引擎优化
一.前言 MySQL 提供的非常丰富的存储引擎种类供大家选择,有多种选择固然是好事,但是需要我们理解掌握的知识也会增加很多.本章将介绍最为常用的两种存储引擎进行针对性的优化建议. 二.MyISAM存储 ...
- MySQL性能调优与架构设计——第11章 常用存储引擎优化
第11章 常用存储引擎优化 前言: MySQL 提供的非常丰富的存储引擎种类供大家选择,有多种选择固然是好事,但是需要我们理解掌握的知识也会增加很多.每一种存储引擎都有各自的特长,也都存在一定的短处. ...
- MySQL性能调优与架构设计——第3章 MySQL存储引擎简介
第3章 MySQL存储引擎简介 3.1 MySQL 存储引擎概述 MyISAM存储引擎是MySQL默认的存储引擎,也是目前MySQL使用最为广泛的存储引擎之一.他的前身就是我们在MySQL发展历程中所 ...
- 详解mysql体系结构和存储引擎
概述 之前整理的一些mysql方面内容,适合做备忘,因为我基本不会去记这些概念性的东西,大家做个了解就可以了. 一.定义数据库和实例 1.数据库: 物理操作系统文件或其他形式文件类型的集合. 在MyS ...
- 关于MySQL事务和存储引擎常见FAQ
1.什么是事务? 事务就是「一组原子性的SQL查询」,或者说一个独立的工作单元.如果数据库引擎能够成功地对数据库应用该组查询的全部语句,那么就执行该组查询.如果其中有任何一条语句因为崩溃或其他原因无法 ...
- MySQL数据库----存储引擎
什么是存储引擎? 存储引擎说白了就是如何存储数据.如何为存储的数据建立索引和如何更新.查询数据等技术的实现方法.因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操 ...
- mysql缓存、存储引擎
一. mysql查询缓存 查询缓存不是mysql的子系统,却是查询优化和执行子系统不可缺少的组成部分.它不仅可以缓存查询结果,还可以缓存查询结果本身.如果某个查询的结果就在缓存里, 系 ...
- MySQL支持多种存储引擎
MySQL的强大之处在于它的插件式存储引擎,我们可以基于表的特点使用不同的存储引擎,从而达到最好的性能. MySQL有多种存储引擎:MyISAM.InnoDB.MERGE.MEMORY(HEAP).B ...
随机推荐
- 6、SQL Server 数据查询
一.使用SELECT检索数据 数据查询是SQL语言的中心内容,SELECT 语句的作用是让数据库服务器根据客户要求检索出所需要的信息资料,并按照规定的格式进行整理,返回给客户端. SELECT 语句的 ...
- MYSQL 中 update set from where 问题
MySQL 和 SQLSERVER不一样,update set from 一张表的时候 应该改为 UPDATE TABLE_AA INNER JOIN TABLE_BB ON TABLE_AA.ID ...
- 《CoffeeScript应用开发》学习:第三章-构建简单的应用程序
字符串插值 CoffeeScript提供了一种更好的构建字符串的解决方案.在双引号字符串(单引号无效)中使用#{}包含一个动态的值. str = 'Hello, CoffeeScript.' cons ...
- Buffer Cache
Buffer Cache Buffer Cache是SGA区中专门用于存放从数据文件中读取的的数据块拷贝的区域.Oracle进程如果发现需要访问的数据块已经在buffer cache中,就直接读写内存 ...
- List 泛型 集合中 Find 的用法
以前在开发中为了对List,String[].Array进行元素的查找一般都是这样做:List lists = new List();list.add("111");.....fo ...
- linux学习4 网络命令和关机重启
网络命令 write write 用户名 回车后输入信息 以 ctrl+d 保存结束 wall wall [message] //that is all,发送给所有人 ping ping 选项 IP地 ...
- DGV表头双行
try { if (e.RowIndex < 0) { RectangleF _rect = e.CellBounds; Pen _pen = new Pen(Color.Black); Pen ...
- Android Volley完全解析(一),初识Volley的基本用法
1. Volley简介 我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android 系统中主要提供了两种方式来进行 ...
- C# Iterator迭代器的实现方式
C#发展到今天又三种方式实现迭代: 1.非泛型非 yield,这个较简单,代码如下: using System; using System.Collections.Generic; using Sys ...
- navigator对象
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...