XTTS数据迁移方案

  • 前置条件检查

XTTS使用限制较多,V3版本按照本节逐项检查

    1. 目标库操作系统不能是windows

源库:redhut 7.9

目标库:redhut 7.9

    1. 检查数据库时区(两边都需要)

SQL> select dbtimezone from dual;

检查结果两边都一致

    1. 检查数据库时间

SQL> select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual;

检查结果两边都一致

    1. 检查数据库字符集

SQL> set linesize 120

SQL> select * from nls_database_parameters where parameter like '%CHARACTERSET%';

检查结果两边都一致

    1. 检查目标端补丁情况

 select 'opatch',comments from dba_registry_history;

目标库需要比源库补丁高

    1. 检查两边组件安装

 SQL> Select comp_name from dba_registry;

如果两边安装了不一样的组件,请注意。

    1. 检查是否使用了 Key Compression 的索引组织表

 Select index_name,table_name from dba_indexes where compression='ENABLED';

    1. 检查sys和system用户在业务表空间上是否创建对象

SQL> select table_name, owner, tablespace_name from dba_tables where tablespace_name not in('SYSTEM','SYSAUX') and owner in ('SYS','SYSTEM');

如果数据库用户 SYS、SYSTEM 在业务表空间上创建有对象,则这些对象不能通过 XTTS 迁移,需要在目标库手工创建。

    1. 检查sys和system用户在业务表空间上是否创建对象

SQL> show parameter compatible;

如果目标端数据库版本是 19.0.0 或更低。那么需要在目标端装 19.0.0以上版本 并创建实例,然后用来进行备份集转换。如果 19.0.0以上版本 中转实例使用 ASM。那么 ASM 版本也必须是 19.0.0以上版本,否则报错 ORA-15295

    1. 确认生产库的recycle in功能是关闭,并手工清空回收站

SQL> show parameter recyclebin;

如果数据库这个功能没有关闭,我们需要去关闭一些

SQL> alter system set recyclebin='off' scope=spfile;

    1. 数据文件状态检查

SQL> Select distinct status from v$datafile;

正常返回应为:ONLINE、SYSTEM

    1. 查看v$transportable_platform检查平台信息

SQL> col PLATFORM_NAME format a50

SQL> select * from v$transportable_platform;

    1. 测试数据构建

可以查看《oracle数据库验证数据构造方案》

  • 数据迁移
    1. 创建源端和目标端用于存放备份数据文件夹

 pwd

mkdir xtts

ls

cd xtts/

ll

mkdir source_back

mkdir source_incr_back

mkdir target_data

mkdir target_back

mkdir target_incr_back

    1. 下载并解压rman_xttconvert_v3工具

unzip rman_xttconvert_v3.zip

[oracle@source xtts]$ ls

su

chmod -R 775 xtts/

ll

    1. 编辑和配置xtt.properties文件

tablespaces=MYTBS      # 表示需要迁移的表空间

platformid=13    # 表示源OS平台ID

#srclink=TTSLINK   #表示从目标库指向源库的db_link,由于这里采用的是rman方式,所以不需要db_link

dfcopydir=/u01/app/oracle/xtts/source_back #表示源库备份文件存放目录

backupformat=/u01/app/oracle/xtts/source_incr_back #表示源库增备文件存放目录

stageondest=/u01/app/oracle/xtts/target_back #表示目标库备份文件存放目录

storageondest=/u01/app/oracle/xtts/target_data  #表示目标库正式文件存放目录

backupondest=/u01/app/oracle/xtts/target_incr_back #表示目标库增备文件存放目录

parallel=3  #表示备份转化并行度

rollparallel=2 #表示增备的并行度

getfileparallel=4  #表示使用 dbms_file_transfer 方式的并行度

    1. 将源端xtts目录拷贝到目标端

scp -rp /u01/app/oracle/xtts/ root@192.168.238.21:/u01/app/oracle/xtts

    1. 设置源端和目标端的TMPDIR环境变量

su - oracle

vi .bash_profile

export TMPDIR=/u01/app/oracle/xtts

source .bash_profile

    1. 源端和目标端开启归档模式并且换日志

SQL> archive log list

目标端修改为归档模式

SQL> alter system switch logfile;

SQL> archive log list

    1. 源端执行如下命令开始初始备份

cd /u01/app/oracle/xtts/

$ORACLE_HOME/perl/bin/perl /u01/app/oracle/xtts/xttdriver.pl -p

    1. 源端查看备份文件,并将备份文件传到目标端

[oracle@oramig source_back]$  scp -p /u01/app/oracle/xtts/source_back/*  root@192.168.238.21:/u01/app/oracle/xtts/target_back

目标端给权限

    1. 将源端生成的rmanconvert.cmd文件传到目标端,并执行文件转换命令

scp -p rmanconvert.cmd root@192.168.238.21:/u01/app/oracle/xtts/

    1. 目标端执行如下命令

$ORACLE_HOME/perl/bin/perl /u01/app/oracle/xtts/xttdriver.pl -c

转换成功之后会生成 xttnewdatafiles.txt文件。

    1. 开始增量同步

SQL> alter tablespace MYTBS read only;

    1. 将最后的增备文件传到目标端

Pwd

$ORACLE_HOME/perl/bin/perl /u01/app/oracle/xtts/xttdriver.pl -i

cd source_incr_back/

Ls

scp -p 0f2ntcso_1_1 root@192.168.238.21:/u01/app/oracle/xtts/target_back

cd ..

scp -p xttplan.txt tsbkupmap.txt root@192.168.238.21:/u01/app/oracle/xtts

目标端修改权限

    1. 目标端应用增备

$ORACLE_HOME/perl/bin/perl /u01/app/oracle/xtts/xttdriver.pl -r

    1. 源端导出元数据

mkdir -p /u01/app/oracle/data

SQL> create directory source_dbdata as '/u01/app/oracle/data';

SQL> grant read,write on directory source_dbdata to system;

SQL> select * from dba_directories;

    1. 源端检查表空间的自包含性

SQL> EXECUTE DBMS_TTS.TRANSPORT_SET_CHECK('MYTBS', TRUE);

 

SQL> SELECT * FROM TRANSPORT_SET_VIOLATIONS;

    1. 源端导出元数据

cd //u01/app/oracle/data

expdp system/123456 directory=source_dbdata dumpfile=MYTBS.dmp transport_tablespaces=MYTBS transport_full_check=y

ls

    1. 将导出的数据拷贝到目标端

scp -p /u01/app/oracle/data/MYTBS.dmp root@192.168.238.21:/u01/app/oracle/data

    1. 目标端导入元数据

创建zgc用户,但是不要创建表空间

SQL> create user zgc identified by 123456;

SQL> grant dba to zgc;

SQL> create directory t_dbdata as '/u01/app/oracle/data';

SQL> grant read,write on directory t_dbdata to zgc;

SQL> grant exp_full_database,imp_full_database to zgc;

目标端导入元数据

pwd

impdp zgc/123456 DUMPFILE=MYTBS.dmp DIRECTORY=t_dbdata TRANSPORT_DATAFILES=/u01/app/oracle/xtts/target_data/MYTBS_8.dbf ,/u01/app/oracle/xtts/target_data/MYTBS_9.dbf

    1. 目标端更改zgc默认表空间

SQL> alter user zgc default tablespace MYTBS;

更改表空间zgc状态为读写

SQL> ALTER TABLESPACE MYTBS read write;

    1. 源端目标端数据比较

源端

目标端

  • 问题分析
    1. 问题一

system 用户没设置密码 设置一下就行了

    1. 问题二

目标端创建zgc用户时

SELECT DEFAULT_TABLESPACE FROM USER_TABLESPACES WHERE USERNAME = ‘zgc’;

说无效的用户名

解决方法:

ALTER SESSION SET "_oracle_script"=true;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/545369.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

自然语言处理NLP关键知识点

大家好,在人工智能出现之前,机器智能处理结构化的数据,例如 Excel 里的数据。但是网络中大部分的数据都是非结构化的,例如文章、图片、音频、视频等。在非结构数据中,文本的数量是最多的,他虽然没有图片和视…

Compose UI 之 Card 卡片组件

Card Card 是用于显示带有圆角和可选阴影的矩形内容容器。它通常用于构建用户界面,并可以包含标题、文本、图像、按钮等元素,表示界面上的可交互元素,我们称它是 “卡片”。 Card 使用的一些经典的场景: 列表数据,例如 新闻列表,产品列表等。信息提示框,使用 Card 组件…

升级win11后无线鼠标失灵,win11鼠标用不了

鼠标失灵是常见的设备故障问题,今天带来相关的解决方法,本文主要是针对升级win11后无线鼠标失灵的处理方法。不少小伙伴在使用电脑的过程中,都遇到过鼠标移动缓慢或者动不了的情况,升级到win11系统的小伙伴也不例外。一般刚升级新系统后,才出现的鼠标失灵问题,那么可能会…

计算机网络——网络地址转换(NAT)技术

目录 前言 前篇 引言 SNAT(Source Network Address Translation)源网络地址转换 SNAT流程 确定性标记 DNAT(Destination Network Address Translation,目标网络地址转换) NAT技术重要性 前言 本博客是博主用于…

SENet模型原理及代码介绍

一.模型简介: SENet的全称叫Squeeze-and-Excitation Networks(挤压-激励网络,简称SENet),于2017年提出,并拿下了当年的ImageNet分类比赛的冠军。ResNet是2015年ImageNet的冠军,2016年ResNeXt&am…

暖宝轻工机械有限公司现已加入2024第13届生物发酵展

参展企业介绍 公司坐落于富饶的长江三角洲,美丽的瓯越山水---温州,成立20多年来,专业从事换热器新品研发、应用设计、生产制造、销售服务为一体的综合性生产企业。 公司致力于食品、饮料、果酒、制药、暖通、化工等行业领域的加热冷却、蒸发…

Magnet AXIOM 7.8 Windows Multilingual - 数字取证与分析

Magnet AXIOM 7.8 Windows Multilingual - 数字取证与分析 Digital Forensic Software 请访问原文链接:https://sysin.org/blog/magnet-axiom/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 恢复并分析一个案件中…

商业照明专用SLM211A系列24V,15mA到200mA支持PWM调光功能的线性恒流LED驱动芯片

SLM211A系列SLM211AAC-7GTR--SOT23-6,SLM211ACB-13GTR--SOP8-EP是用于产生单通道、高精度恒流源的 LED 驱动芯片,在各种 LED 照明产品中非常简单易用。SLM211A 具有宽输入电压范围、高输出精度、超低 drop-out 压降、卓越的线性/负载调整率等特性&#x…

Python中的list()和map() 用法

list() 在Python中,list() 是一个内置函数,用于创建列表(list)对象。它有几个不同的用途,但最常见的是将一个可迭代对象(如元组、字符串、集合或其他列表)转换为一个新的列表。 以下是一些使用…

理解计算中的随机性与伪随机性:Avi Wigderson的理论计算科学贡献

目录 前言1 随机性和伪随机性在计算中的角色2 随机性的动态理解3 伪随机性的应用4 理论到实践的应用结语 前言 近期,普林斯顿大学数学教授Avi Wigderson荣获了2023年图灵奖,以表彰他在理论计算机科学领域的杰出贡献。他的研究聚焦于计算复杂性理论&…

ODI(境外投资备案)作用、类别和申请流程详解

中国企业越来越多地选择在境外进行投资,而国家相关部门也出台了多项政策以规范这一行为。在进行海外投资前,企业必须在政策指导下进行合法操作并办理相应手续,其中ODI(境外投资备案)是其中一种最常见的方式之一。 以…

太好玩了,我用 Python 做了一个 ChatGPT 机器人

毫无疑问,ChatGPT 已经是当下编程圈最火的话题之一,它不仅能够回答各类问题,甚至还能执行代码! 或者是变成一只猫 因为它实在是太好玩,我使用Python将ChatGPT改造,可以实现在命令行或者Python代码中调用。…

华为昇腾AI芯片加持,9.1k Star 的 Open-Sora-Plan,国产Sora要来了吗

Aitrainee | 公众号:AI进修生 哇,今天Github趋势榜第一啊,为了重现Sora,北大这个Open-Sora-Plan,希望通过开源社区力量的复现Sora,目前已支持国产AI芯片(华为昇腾),这回不用被卡脖子…

LoRa无线电机温振传感器,FlexLua低代码技术助力快速实现。

在物联网时代,无线传感技术的应用愈发广泛。其中,LoRa(长距离低功耗无线技术)作为一种适用于远距离、低功耗的通信技术,被广泛应用于各种物联网场景。而结合温度和振动传感技术,能够构建出用于监测机器状态…

UE5学习日记——制作多语言版本游戏,同时初步学习UI制作、多语言化、控制器配置、独立进程测试、打包配置和快速批量翻译等

所有的文本类,无论变量还是控件等都能实现本地化,以此实现不同语言版本。 在这里先将重点注意标注一下: 所有文本类的变量、控件等都可以多语言;本地化控制板中收集、编译时,别忘了编译这一步;支持批量复制…

【蓝桥杯 2020 省 A2】门牌制作 题解(Word+Excel+提交答案)

问题描述 小蓝要为一条街的住户制作门牌号。 这条街一共有2020位住户,门牌号从1到2020编号。 小蓝制作门牌的方法是先制作0到9这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌1017需要依次粘贴字符1、0、1、7,即需要1…

802.1X认证原理

IEEE802 LAN/WAN委员会为解决无线局域网网络安全问题,提出了802.1X协议。后来,802.1X协议作为局域网接口的一个普通接入控制机制在以太网中被广泛应用,主要解决以太网内认证和安全方面的问题。 802.1X协议是一种基于接口的网络接入控制协议。…

python的算术运算符

python常用算术运算符代码如下: #算术运算符操作 x 10 y 20 z 30 #加法运算 a x y print("a的值为:", a) #减法运算 a x - y print("a的值为:", a) #乘法运算 a x*y print("a的值为:", a) …

FFmpeg: 自实现ijkplayer播放器--06封装打开和关闭stream

文章目录 流程图stream openstream close流程图 stream open 初始化SDL以允许⾳频输出;初始化帧Frame队列初始化包Packet队列初始化时钟Clock初始化音量创建解复用读取线程read_thread创建视频刷新线程video_refresh_threadint FFPlayer::stream_open(const char

LangChain简明讲义:从0到1构建LLM应用程序

🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 往期热门专栏回顾 专栏…