oracle9i升级oracle10g
运用transport tablespace进行快速oracle版本升级(9i-10g)
大家可能都知道在进行oracle数据库版本升级的时候会有2种方式
1.通过dbua(database upgrade assistant)
2.exp/imp
通过dbua来升级的话由于不涉及到数据文件的改变,所以速度会比较快,但是如果dbua一旦在升级的过程中出现问题可能会导致原来的库不可用。
而通过exp/imp虽然对原来的库不会有影响,但是如果数据库比较大的话那么升级的时间将会是不可接受的(尤其对24*7)的应用来说。
针对这个问题,这次的2006 oracle openworld法国的amadeus公司提供了一个非常有创意的点子,就是利用dataguard和transport tablespace功能来实现最短时间内的安全升级。
首先让我们来了解一下amadeus公司
艾玛迪斯全球旅游分销系统公司(Amadeus Global Travel Distribution SA)是全球领先的旅游行业技术及分销供应商。1987年艾玛迪斯总部建立于西班牙马德里。在 Sophia Antipolis(法国尼斯附近)和美国波士顿设立有市场及开发部门。公司的数据中心位于德国慕尼黑附近的Erding。公司提供各种先进的旅游行业技术解决方案,至今已成为成长最快并被最广泛使用的全球分销系统(GDS)。
作为卓越的技术合作伙伴,艾玛迪斯把最先进的信息技术带入旅游行业,使众多的旅游供应商、休闲及商务旅游服务商从中获益。通过设立服务于当地市场的national marketing companies(NMCs),艾玛迪斯用其庞大的信息技术资源向全世界200个国家和地区提供优质的技术解决方案。
我们再来看一下跟它们的数据库相关的信息
他们的业务系统达到99.99%的可用率,每秒钟有30万次的数据库请求,每天有2亿8千万次transaction,这是一个相当大的数据库系统,如果用dbua或者exp/imp他们都不能接受升级的风险,于是他们的技术人员就想出了用dataguard和transport tablespace功能来实现最短时间内的安全升级。
具体的实现方法是这样的
1.先为主库建立一个dataguard数据库(可以在线做)
2.在dataguard库上安装10g软件(可以在线做)
3.整理一些不能通过transport tablespace搞定的东西,比如sequence,synonyms,grants......
4.停止主库这边所有write的应用,提供read的服务(写入停止,提供查询)
5.强制归档主库redo log并传到dataguard恢复(写入停止,提供查询)
6.利用transport tablespace来转换数据库版本,并创建sequencee,synonyms,grants等(写入停止,提供查询)。
7.验证新环境的过程,在验证过程中如果发现有问题,则可以切换会原来的系统(写入停止,提供查询)。
8.切换应用到10g数据库(提供服务)
amadeus在演习时做到10分钟内完成4,5,6,7并成功切换了系统,考虑到他们的数据库繁忙程度和数据库容量非常大,这真是一项伟大的成就。我们可以在以后的数据库版本的升级过程中借鉴他们的方法。
我们再从技术上验证一下transport tablespace可以运用在版本升级
在9i的库上创建一个test tablespace
create tablespace test
datafile '/opt/oracle/test.dbf' size 10m
extent management local autoallocate;
创建一张表在test表空间上
create table test1(a number) tablespace test;
insert into test1 values(1);
commit;
SQL 9i>select * from test1;
A
----------
1
把test表空间置为read only模式
alter tablespace test read only;
到处test tablespace的metadata
exp /'sys/sys as sysdba/' transport_tablespace=y tablespaces=(TEST) file=test.dmp log=test.log
传输dmp文件和数据文件(在amadeus的案例里面由于10g的库和9i的库在同一台机器上,所以避免了拷贝数据文件的时间,这也是整个方案的重点之一)到远程
scp test.dmp oracle@10.0.100.115:/opt/oracle/
scp /opt/oracle/test.dbf oracle@10.0.100.115:/opt/oracle/
在目标库上导入metadata数据
imp /'sys/sys as sysdba/' transport_tablespace=y tablespaces=(TEST) file='/opt/oracle/test.dmp' datafiles=
('/opt/oracle/test.dbf') tts_owners=test fromuser=test touser=test log=tts_i.log
查看test1表,发现数据一致
SQL 10G>select * from test1;
A
----------
1
把test表空间置为read write模式
alter tablespace test read write;
insert into test1 values(2);
SQL 10G>select * from test1;
A
----------
1
2
一切正常,测试完毕
这个测试简单的模仿了transport tablespace升级数据库的可能性,当然在实际过程中我们要校验是否自包含表空间,是否需要创建sequence等,但是总体来说这种方案能提供最短时间内的数据库版本升级。
oracle9i升级oracle10g相关推荐
- Oracle9i升级到oracle10g
一.升级环境及目的: 目的:一般是由于业务规划,现有oracle9i的版本不能满足需求,需要跨大版本升级. 环境:我实验的环境如下: 升级前 升级后 OS 版本 Linux AS4( 32bit) L ...
- oracle分区表扩分区 很慢,升级oracle10g 大分区表update变慢
原来使用的数据库是oracle8.1.7.4 这次升级为oracle 10.0.2.4,在导入旧dmp时候明显能够感觉到导入数据比较快. 1.可是在正式使用之后,发现启用一个大表(使用了分区表), ...
- his系统服务器选择,我院完成HIS服务器及数据库的升级改造
随着我院信息化建设的发展,医院HIS服务器7×24h满负荷运转,运行压力非常大,常常出现门诊高峰期收费响应慢.报表数据读等待时间长的现象,严重影响我院工作效率. 为解决这一难题,在院领导的支持下开始进 ...
- oracle+12514+C#,Oracle10g ORA-12514
问题描述: Oracle9i与Oracle10g之间互换使用:配置Oracle10g且启动实例后,PLSQL连接数据库时,出现如下错误: ORA-12514: TNS: 监听程序当前无法识别连接描述符 ...
- Latch free等待事件
原文:oracle waitinterface-a practical guide to performance diagnostics & tuning Richmond shee Kirt ...
- oracle装一半报错要卸掉,OpenSUSE下oracle11gR2的安装卸载
OS OpenSUSE-11.4 DB版本 Oracle 11g R2 先说卸载: 1.rm /etc/oratab 2.rm -rf /$ORACLE_BASE 3.rm -rf oraInvent ...
- 上海Oracle用户组我的页面
上海Oracle用户组 SHOUG,走近全系Oracle技术和数据库专家 Menu Skiptocontent 活动 SHOUG成员 CategoryArchives:SHOUG成员 SHOUG成员– ...
- ORACLE OCP 考试指南
oracle OCP指南 1.1 概述 OCP是oracle公司推出的一项认证计划,全称为:oracle Certified Professional.由于oracle数据库在全球高端数据库领域占有 ...
- oracle OCP指南
oracle OCP指南 1.1 概述 OCP是oracle公司推出的一项认证计划,全称为:oracle Certified Professional.由于oracle数据库在全球高端数据库领域占有 ...
最新文章
- 00后MIT美女学霸获2022年罗德奖学金!4位中国学霸入学牛津
- python对输入的字符串进行解析_python数据类型_字符串常用操作(详解)
- 如何在大流量场景下云淡风轻地进行线上发布?
- php 跳转到指定url_PHP想要实现页面跳转功能具体怎么操作?(函数标签示例)...
- 学JAVA要学redis_新手学习Java对Redis简单操作
- 为什么谷歌要执行严格的代码编写规范
- Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18)
- 若依集成 WebSocket
- 2019-11-20 git提交日志中附加的贡献者签名
- mysql 自动备份脚本+自动上传
- 眉山市谷歌高清卫星地图下载
- 实验室安全,研究生生涯发展与规划平时练习答案,雨课堂/学堂云
- krohne流量计接线图_电磁流量计接线方式
- 初中毕业学修车还是学计算机,儿子初中毕业了,成绩不好,想学门手艺谋生,去技校,还是去店里做学徒好?学修车吗?...
- 办公协同:xmind8案例实战班-Array老师-专题视频课程
- java里如何表示黑桃方片_扑克牌中(黑桃,方片,红心,梅花)各代表什么意思?据我所知红心是代表爱。...
- QQ能上网但是浏览器上不了网
- 以管理员身份运行闪退怎么解决_win7右击获得管理员权限时窗口闪退
- seo关键词优化技巧是什么
- QTabBar 和 QTabWidget部件 页签