DB2中配置文件不被映像文件覆盖的方法

本文将为您介绍DB2数据库中避免目标数据库中的配置文件不被映像文件中的所覆盖的方法。 供您参考,希望对您有所帮助。

在将DB2 用BACKUP 命令方式创建的数据库备份映像文件由RESTORE命令复原到一个不同名的目标数据库中时,DB2 将把源数据库中的配置文件复制到复原的目标数据库中,从而覆盖了该数据库原有的各配置参数的设置。在此提供一种避免目标数据库中的配置文件不被映像文件中的所覆盖的方法。

一. 数据库种子值的概念:

在介绍这一方法之前,首先要介绍一下数据库种子值(seed)的概念,它是数据库的唯一标识,在数据库的整个生命周期中,这个值都将始终保持不变。种子值是在数据库创建时由数据库管理器指定的,而在复原操作中,DB2 始终使用的是备份映像中的种子值。为获取备份映像中的种子值,可通过 DB2ckbkp 命令从输出中查询。

 将一个DB2 数据库的全备份映像复原到一个已存在的数据库中时,两个数据库的别名,数据库名,及种子值都可能不相同,复原实用程序将对该数据库进行一系列的操作,其中包括的一项操作就是比较源和目标数据库的两个种子值,如果种子值不同,则将备份映像中的数据库配置文件复制到目标数据库中,以覆盖其原有的各配置参数;如果两个值相同,则保留目标数据库中的配置文件。

二. 结合实例说明实现的步骤:

下面我们举例说明避免复原DB2 数据库备份映像至不同名数据库时,目标数据库的配置文件被映像中的所覆盖的方法,这里源数据库名SAMPLE,目标数据库名为TEST,以对数据库参数UTIL_HEAP_SZ 的修改来举例:

·源数据库种子值的获取:

1. 查看源数据库中 UTIL_HEAP_SZ 的值:

DB2 get db cfg for sample |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 5000

2. 脱机全备份源数据库:#p#

DB2 backup db sample
备份成功。此备份映像的时间戳记是:20050117162957

3. 查找源数据库的种子值:

DB2ckbkp -H SAMPLE.0DB2NODE0000CATN00000501172957.001

=====================
MEDIA HEADER REACHED:
=====================

Server Database Name — SAMPLE
Server Database Alias — SAMPLE
Client Database Alias — SAMPLE
Timestamp — 20050117162957
Database Partition Number — 0
Instance — DB2
Sequence Number — 1
Release ID — A00
Database Seed — 423AD856
:
:

从输出中可知 SAMPLE 数据库的种子值为 423AD856。

·目标数据库种子值的获取:#p#

4. 创建目标数据库:

DB2 create db test

5. 查看目标数据库中 UTIL_HEAP_SZ 的值:

DB2 get db cfg for test |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 5000

6. 更改目标数据库中参数值,并确认已与源数据库的值不同:

DB2 update db cfg for test using util_heap_sz 10000
DB2 get db cfg for test |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 10000

7. 脱机全备份目标数据库:

DB2 backup db test
备份成功。此备份映像的时间戳记是:20050126144943

8. 查找目标数据库的种子值:

DB2ckbkp -H TEST.0DB2NODE0000CATN00000501264943.001

=====================
MEDIA HEADER REACHED:
=====================#p#
Server Database Name — TEST
Server Database Alias — TEST
Client Database Alias — TEST
Timestamp — 20050126144943
Database Partition Number — 0
Instance — DB2
Sequence Number — 1
Release ID — A00
Database Seed — 41F7C3EA
:
:

从输出中可知 TEST 数据库的种子值为 423AD856,也就是说,源和目标数据库库的种子值是互不相同的,它们分别唯一标识了源数据库 SAMPLE 和目标数据库 TEST。

·第一次复原操作(种子值不相同时):

9. 将源数据库的映像文件复原到目标数据库中:

DB2 restore db sample into test
SQL2528W 警告!复原到与备份映像数据库相同的现有数据库,但是现有数据库的别名 “TEST” 与备份映像的别名 “SAMPLE” 不匹配,并且现有数据库的数据库名 “TEST” 与备份映像
的数据库名 “SAMPLE” 不匹配。目标数据库将被备份版本覆盖。
想要继续吗?(y/n)y

10.复原操作完成后,再次查看目标数据库中 UTIL_HEAP_SZ 的值:#p#

DB2 get db cfg for test |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 5000

可以看到尽管在进行复原操作之前,TEST 库中的 UTIL_HEAP_SZ 已被修改为 10000,但完成了复原操作之后,这一参数又被改回 5000,这就是由于源和目标库的种子值不同,复原操作会将备份映像配置文件复制到目标数据库中,从而覆盖了原来目标数据库的配置所导致的,所以 UTIL_HEAP_SZ 参数的值由原来的 10000 覆盖回备份映像中的 5000。

·第一次复原操作后检查目标库的种子值变化:

11.复原操作完成后,再次脱机备份目标数据库:

DB2 backup db test
备份成功。此备份映像的时间戳记是:20050126145640

12.利用新的备份映像再次查找目标数据库的种子值:

DB2ckbkp -H 145640.001

=====================
MEDIA HEADER REACHED:
=====================
Server Database Name — TEST#p#
Server Database Alias — TEST
Client Database Alias — TEST
Timestamp — 20050126145640
Database Partition Number — 0
Instance — DB2
Sequence Number — 1
Release ID — A00
Database Seed — 423AD856
:
:

可以发现,复原操作之后目标数据库 TEST 的种子值已和源数据库 SAMPLE 的相同,均为 423AD856 了!这说明目标数据库在复原操作的过程中获取了备份映像中种子值,覆盖了原种子值。

·第二次复原操作(种子值相同时):

13.再次更改目标数据库中参数值,并确认更改已生效:

DB2 update db cfg for test using util_heap_sz 15000
DB2 get db cfg for test |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 15000

14.再次将源数据库的映像文件复原到目标数据库中:

DB2 restore db sample into test

15.复原操作完成后,再对目标数据库中 UTIL_HEAP_SZ 的值进行查看:

DB2 get db cfg for test |find /i “util_”
实用程序堆大小(4KB) (UTIL_HEAP_SZ) = 15000

可以看到,这次对目标数据库参数的修改未被刚完成的复原操作所使用的源数据库映象所覆盖,其原因就在于在这一复原操作之前,目标数据库的种子值已因第一次的复原操作而与源数据库的相同,从而未触发覆盖目标数据库配置文件的操作,这样就最终实现了避免复原 DB2 数据库备份映像文件至不同名数据库时,目标数据库的配置文件被映像中的所覆盖的情况。
 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/238091.html<

(0)
运维的头像运维
上一篇2025-04-22 18:58
下一篇 2025-04-22 18:59

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注