author:skate
time:2009-09-11
网上看到一篇oracle9i升级oracle10g的文章,觉得不错.记录下来
你可以参考汪海的文章 http://wzwanghai.spaces.live.com ... 37AFBD116!355.entry
运用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相关推荐

  1. Oracle9i升级到oracle10g

    一.升级环境及目的: 目的:一般是由于业务规划,现有oracle9i的版本不能满足需求,需要跨大版本升级. 环境:我实验的环境如下: 升级前 升级后 OS 版本 Linux AS4( 32bit) L ...

  2. oracle分区表扩分区 很慢,升级oracle10g 大分区表update变慢

    原来使用的数据库是oracle8.1.7.4   这次升级为oracle 10.0.2.4,在导入旧dmp时候明显能够感觉到导入数据比较快. 1.可是在正式使用之后,发现启用一个大表(使用了分区表), ...

  3. his系统服务器选择,我院完成HIS服务器及数据库的升级改造

    随着我院信息化建设的发展,医院HIS服务器7×24h满负荷运转,运行压力非常大,常常出现门诊高峰期收费响应慢.报表数据读等待时间长的现象,严重影响我院工作效率. 为解决这一难题,在院领导的支持下开始进 ...

  4. oracle+12514+C#,Oracle10g ORA-12514

    问题描述: Oracle9i与Oracle10g之间互换使用:配置Oracle10g且启动实例后,PLSQL连接数据库时,出现如下错误: ORA-12514: TNS: 监听程序当前无法识别连接描述符 ...

  5. Latch free等待事件

    原文:oracle waitinterface-a practical guide to performance diagnostics & tuning Richmond shee Kirt ...

  6. oracle装一半报错要卸掉,OpenSUSE下oracle11gR2的安装卸载

    OS OpenSUSE-11.4 DB版本 Oracle 11g R2 先说卸载: 1.rm /etc/oratab 2.rm -rf /$ORACLE_BASE 3.rm -rf oraInvent ...

  7. 上海Oracle用户组我的页面

    上海Oracle用户组 SHOUG,走近全系Oracle技术和数据库专家 Menu Skiptocontent 活动 SHOUG成员 CategoryArchives:SHOUG成员 SHOUG成员– ...

  8. ORACLE OCP 考试指南

    oracle OCP指南 1.1  概述 OCP是oracle公司推出的一项认证计划,全称为:oracle Certified Professional.由于oracle数据库在全球高端数据库领域占有 ...

  9. oracle OCP指南

    oracle OCP指南 1.1  概述 OCP是oracle公司推出的一项认证计划,全称为:oracle Certified Professional.由于oracle数据库在全球高端数据库领域占有 ...

最新文章

  1. 00后MIT美女学霸获2022年罗德奖学金!4位中国学霸入学牛津
  2. python对输入的字符串进行解析_python数据类型_字符串常用操作(详解)
  3. 如何在大流量场景下云淡风轻地进行线上发布?
  4. php 跳转到指定url_PHP想要实现页面跳转功能具体怎么操作?(函数标签示例)...
  5. 学JAVA要学redis_新手学习Java对Redis简单操作
  6. 为什么谷歌要执行严格的代码编写规范
  7. Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18)
  8. 若依集成 WebSocket
  9. 2019-11-20 git提交日志中附加的贡献者签名
  10. mysql 自动备份脚本+自动上传
  11. 眉山市谷歌高清卫星地图下载
  12. 实验室安全,研究生生涯发展与规划平时练习答案,雨课堂/学堂云
  13. krohne流量计接线图_电磁流量计接线方式
  14. 初中毕业学修车还是学计算机,儿子初中毕业了,成绩不好,想学门手艺谋生,去技校,还是去店里做学徒好?学修车吗?...
  15. 办公协同:xmind8案例实战班-Array老师-专题视频课程
  16. java里如何表示黑桃方片_扑克牌中(黑桃,方片,红心,梅花)各代表什么意思?据我所知红心是代表爱。...
  17. QQ能上网但是浏览器上不了网
  18. 以管理员身份运行闪退怎么解决_win7右击获得管理员权限时窗口闪退
  19. seo关键词优化技巧是什么
  20. QTabBar 和 QTabWidget部件 页签

热门文章

  1. 全国计算机电脑系统有问题吗,笔记本重装系统对电脑有影响吗
  2. php提取视频音乐,如何从视频里提取音乐伴奏
  3. 华为p10多屏互动在哪_华为p10如何投屏到电视?手机还有这些使用技巧
  4. 华为南研所机考练习2-计算麻将的番数
  5. 【PyTorch】随机种子 与 网络初始化
  6. AES加密解密算法的C代码实现
  7. 推荐一款智能黑科技微信小程序,简直不要太良心!
  8. 软件测试的目的和原则是什么?
  9. 使用tarjan算法和fleury算法求解中国邮递员问题
  10. 微信小程序名片3:0大战纸质名片,你应该知道如何选择了吧