DB2数据备份和恢复的操作流程

  本文主要讲述了如何提高DB2数据备份和恢复效率的实际操作步骤,在设计数据备份和恢复的方案时,我们主要考虑的有两个方面的问题。

  一是备份与恢复策略本身是否安全,即能否及时的准确的完成对数据库的备份工作。

  二是要考虑数据备份与恢复方案的执行效率高不高。

  如果备份或者恢复一个DB2数据库需要花费几个小时时间,那么及时这个备份与恢复方案再安全,也于事无补。或者说,是一个不合适的解决方案。为此在考虑备份恢复方案本身安全性的同时,也需要兼顾备份与恢复的效率。在这篇文章中,笔者就介绍一下提高DB2数据备份与恢复效率的一些常用技巧。

  经过笔者多个案例的实际应用,证明这些技巧在提高DB2数据库备份与恢复的性能具有很大的帮助。

  一、了解数据的逻辑存储结构。

  如果以前有Oracle数据库经验的管理员,那么了解DB2数据库的逻辑存储结构就比较容易了,因为两者在这方面很类似。对于DB2数据库来说,其逻辑存储结构主要分为数据表、表空间与数据库三个级别。数据表包含在表空间之中,而表空间又包含在数据库当中。换一句话说,一个DB2数据库包含多个表空间,而每个表空间又包含了多个数据表。

  一个数据表示不能够保存在多个表空间当中的。同理,一个表空间也不能够保存在多个数据库之中。这跟小学的实施,班级里分组类似。一个班(相当于一个数据库)分为四个小组(每个小组相当于一个表空间),然后每个小组又是由一个个的学生组成的(一个个学生相当于一个个数据表)。

  这个组织结构可以有什么好处呢?此时学校校长(相当于数据库管理员)就可以按照班级、小组为单位对数据进行管理,也可以对学生进行一对一的面谈,从而提高数据库管理的灵活性。

  而对于DB2数据备份与恢复作业来说,采用如此的逻辑结构,数据库管理员既可以对整个数据库进行备份与恢复(对整个班级进行管理);也可以以表空间为单位,对表空间中的所有数据表进行备份与恢复操作(以小组为单位进行管理);甚至可以对单独的数据表进行备份与恢复的操作(对单个学生进行管理)。即可以分别从数据表、表空间、数据库三个级别来进行备份与恢复的操作。

  这分级别的管理,不仅增强了操作的灵活性,而且还可以提高备份与操作的效率。如现在用户需要对某个表进行更新,如需要调整价格表中的价格。此时数据库管理员就只需要对价格表进行更新即可,而不需要对整个数据库进行备份。显然这可以减少备份的时间。若出现问题的话,也只需要对这张表中的内容进行恢复。这也可以在很大程度上减少恢复的时间。恢复一张表肯定比恢复整个数据库所用的时间要少的多。

  二、合理规划表空间提高数据库备份恢复性能。

  既然数据库备份与恢复可以按三个级别来进行,那么数据库管理员可以根据这个特性来合理规划表空间,以提高数据库备份与恢复的性能。如在DB2数据库中,虽然对于LOB等大容量数据类型提供了很好的支持。

  但是,毕竟其容量比较大,有时候其所占的数据库容量可能达到整个数据库的二分之一。为此这些大容量的数据类型就成为了数据库备份与恢复作业作业的性能瓶颈。如果在数据库备份与恢复的时候,不备份这些LOB数据类型的数据,那么数据库备份与恢复的时间可能会减少三分之一,甚至二分之一。

  为此笔者建议,在规划数据表的时候,最好将LOB数据类型的数据与其他数据分成两张表来存放。如在一个产品信息表的表中,包含一个产品图片的字段,这个字段就是一个LOB数据类型。虽然可以将它们设计在同一个表中。不过笔者还是建议将他们分为两个表来存放,然后通过关键字将他们连接起来。

  最后将这个两张表分别存放到不同的表空间中。如将有LOB数据类型的表统一保存在LOB表空间中。如此有什么好处呢?当数据库进行备份时,平时可以只对非LOB表空间中的数据进行备份。由于LOB表空间中的一些信息一般不怎么会更新,就可以一个星期更新一次。或者让其在数据库比较空闲的时间进行备份。

  经过一段时间的测试,可以发现每天或者每周数据库的空闲时断。如此规划的话,就可以将平时备份的效率提高。同理,在恢复的时候也可以按照表空间级别来进行恢复,从而缩短数据库恢复的时间。

  这个方案的核心就是将LOB等大容量数据类型的数据与普通表独立开来,并且存放在不同的表空间中。然后将LOB表空间与非LOB表空间进行分开管理,分开备份与恢复,从而提高数据库备份与恢复的效率。为此在建立表时将LOB数据类型与其他数据类型分开存放是关键。

  三、对于图片等LOB数据类型的另类处理方式。

  当数据库中LOB数据类型比较多的时候,往往会在很大程度上影响数据库的性能。不仅DB2数据备份与恢复会受到影响,连平时的查询也会受到牵连。为此笔者有时候给企业部署DB2数据库系统的时候,往往会建议他们,不要将图片等信息存放在数据库中。那么当用户需要查询图片信息时,该如何处理呢?笔者建议他们将图片统一放到网络上的一个共享服务器中。

  然后在数据库中只存放这个图片的路径。最后在客户端界面设计时,可以创建一个指向图片的链接。当用户需要访问某个产品的图片信息时,则只需要点击产品管理界面上的图片链接,就可以打开这张图片。在这种情况下,数据库实际存储的只是图片的路径(也就是一个普通的字符型字段),而不是图片本身。故可以提高客户端窗口显示的速度,同时也可以提高数据库备份与恢复的效率。

  四、为系统设置合适的并行度与缓存来提高数据库备份与恢复性能。

  数据库备份与恢复的性能除了跟数据类型有关之外,还跟系统的并行度与缓冲区有关。通常情况下,如果硬件设备支持的话,增加并行度与增加缓冲区的大小可以提高数据库备份与恢复的性能。为此在对DB2数据库进行备份的时候,可以通过给并行度、缓冲区树木和缓冲区大小分配合适的值来提高数据库备份与恢复的性能。

  如一般情况下,笔者建议将数据库缓冲区的大小设置为数据内存的二倍到三倍。如果备份中包含大容量的数据类型,可以适当提高整个比例。并且将数据库缓冲区的数目设置为硬盘I/O缓冲数目的两倍。如此设置之后,数据库的备份与恢复性能能够得到很大的改善。

  不过需要注意的是,这个调整会受到服务器硬件资源的限制。当服务器内存等硬件设备不支持这么大的数据缓冲区与数据缓冲区数目时,反而会因为没有足够的内存分配给缓冲区,从而导致DB2数据备份与恢复的失败。为此笔者建议,在调整数据缓冲区的时候,需要特别注意。

  多备份认为:调整好这些参数之后,需要持续追踪一段时间,以确保这些调整不会影响到数据库的正常备份与恢复,不会与数据库的硬件配置相冲突。

www.dbfen.com

时间: 2024-10-16 04:30:54

DB2数据备份和恢复的操作流程的相关文章

mysql大数据备份及恢复(一)

Mysql大数据备份和恢复一 MySQL备份一般采取全库备份.日志备份:MySQL出现故障后可以使用全备份和日志备份将数据恢复到最后一个二进制日志备份前的任意位置或时间:mysql的二进制日志记录着该数据库的所有增删改的操作日志还包括了这些操作的执行时间 Binlog的用途:主从同步.恢复数据库 使用binlog工具备份 查看binlog是否开启,因为默认是关闭的 从上图可知off为关闭状态,一般logbin为只读,在/etc/my.cnf下开启 重启数据库 重启后在目录下查看是否生成bin日志

【windows】环境下mysql的数据备份以及恢复

[windows]环境下mysql的数据备份以及恢复 无论是刚刚入行的'猿友'还是入行很久的'老猿',我相信都会遇到过因为各种原因(很多情况下是自己误删了数据库)的操作.drop databases xxxxx 而误删了线上项目的数据库是一件很恐怖的事情,那么如果大家遇到这种情况怎么办呢?首先不要着急(我感觉说了也白说-,-),先看一看自己的mysql是否开启了binlog日志功能,如果没有???game over !!! 关于查看binlog日志有没有开启,请到自己的Mysql文件下找my.i

MySQL数据库数据备份和恢复详解(上)

本文讨论 MySQL 的备份和恢复机制,以及如何维护数据表,包括最主要的两种表类型:MyISAM和Innodb,文中设计的 MySQL 版本为 5.0.22. 目前 MySQL 支持的免费备份工具有:mysqldump.mysqlhotcopy,还可以用 SQL 语法进行备份:BACKUP TABLE 或者 SELECT INTO OUTFILE,又或者备份二进制日志(binlog),还可以是直接拷贝数据文件和相关的配置文件.MyISAM 表是保存成文件的形式,因此相对比较容易备份,上面提到的几

阿里云RDS数据备份本地恢复

公司现在用的阿里云数据库,阿里云上虽然对RDS数据库有备份,也只能免费保存一个月,所以大部分情况需要把备份下载到本地,但是如何在本地恢复可真是话费了一番功夫.先分享如下: 公司目前使用的数据库是阿里云的RDS,目前RDS的版本为mysql5.6.如下: 现在要求把RDS的数据,在公司内部本地进行恢复. 操作系统:Centos7 数据库:mysql5.6 一.安装mysql数据库 在进行RDS本地恢复数据之前,我们需要先在本地服务器上安装mysql的5.6版本,因为RDS是5.6版本,所以我们本地

表中 的数据 备份 和 恢复

-- 建表 create table emp( sid int(8) primary key, sname varchar(10), sex varchar(2), chu varchar(50), classno varchar(50) ); -- 表中的数据 insert into emp (sname,sex,chu,classno) values ('张石瑞','男','1996-01-02','201701'), ('李佛','女','1998-05-15','201702'), ('

三种VMware数据备份和恢复方法

服务器虚拟化,尤其是VMware形式的服务器虚拟化使IT人员获益良多,这么说一点也不为过.据我们所见,服务器虚拟化能解决服务器扩张.资源消耗.服务器扩张.能源消耗.高可用性等相关问题.服务器虚拟化也使我们有更多的时间解决其它的迫切问题,如企业资源预案升级.存储项目再三迁移. 尽管VMware提供封装技术和抽象技术,使我们受益匪浅,但数据保护领域发生的基本变革也带来了各项挑战.即使出现了VMware虚拟化,备份人员依然是牢骚最多的IT人员.最大的挑战在于保证数据的一致性,解决VMware物理资源过

mysql数据备份及恢复

mysql数据备份: 1数据备份方式: 方式分类: 物理备份:     直接拷贝库或对应的文件,文件的所有者/组必须是mysql cp -r /var/lib/mysql 目录/备份文件名 cp /var/lib/mysql/user.*  /mydata/ tar -zcvf  /mydata/mysal.tar.gz /var/lib/mysql/mysql/* 只支持myisam储存引擎的表       mysqlhotcopy  -u root -p 123456 数据库名   目录/备

GitLab 数据备份和恢复

GitLab 备份 /opt/gitlab/bin/gitlab-rake gitlab:backup:create //只是备份各项目的数据 完成后会在默认路径下多出来备份的tar包! /var/opt/gitlab/backups/XXXXXX.tar GitLab 恢复 # 停止相关数据连接服务 gitlab-ctl stop unicorn gitlab-ctl stop sidekiq # 从1393513186编号备份中恢复 gitlab-rake gitlab:backup:res

大数据备份和恢复应用案例--通过分区表备份和恢复数据

海量数据备份和恢复方案 对于OLAP的数据库的业务特点,是将批量的数据加载入库,然后对这些数据进行分析处理,比如报表或者数据挖掘,最后给业务提供一种决策支持:另外,这类数据库的数据实时性非常高,一旦这些数据处理完毕后,就很少再次使用(有时,也需要对这类数据进行查询). 对于OLAP数据库的备份和恢复可以考虑这样几种方案: 1.使用分布式数据库 将数据分布到多个库里,当数据库恢复时,只需要恢复单个库的数据,大大节省恢复时间. 2.结合分区技术,以传输表空间方式进行备份和恢复 1.建立分区表,将分区