Chinaunix首页 | 论坛 | 博客
  • 博客访问: 360901
  • 博文数量: 86
  • 博客积分: 1460
  • 博客等级: 上尉
  • 技术积分: 848
  • 用 户 组: 普通用户
  • 注册时间: 2009-07-12 14:07
文章分类

全部博文(86)

文章存档

2017年(36)

2016年(17)

2015年(1)

2013年(12)

2012年(2)

2011年(1)

2010年(1)

2009年(16)

我的朋友

分类: Oracle

2013-12-25 14:27:06

Linux(RHEL5)下ORACLE 10g版本升级(10.2.0.1.0-10.2.0.5.0)操作文档

 
 
 

系统环境:RHEL5

文档版本V1.0.1

整理Kevin.Lu

更新时间2011-08-27

备注DBA专用

时间

修改人

版本号

修改说明

2011.08.20

Kevin.Lu

1.0.0

建立文档

2011.08.27

Kevin.Lu

1.0.1

梳理文档

本文档规范oracle10.2.0.1.0升级到10.2.0.5.0版本的升级流程及操作,供DBA人员在进行数据库版本升级的时参考使用。

升级操作的具体步骤如下:

shared pool和java pool的大小

确保参数shared_pool_size和java_pool_size至少为150M大小,保证catupgrd.sql(10g)升级脚本运行正常(9i版本中是catpatch.sql)

[root@10gpri ~]# su – oracle

[oracle@10gpri Disk1]$ sqlplus / as sysdba

SQL>startup

SQL>alter system set shared_pool_size='150M' scope=spfile;

SQL> alter system set java_pool_size='150M' scope=spfile;

SQL>shutdown immediate

oracle软件,备份数据库

[oracle@10gpri Disk1]$cp -r $ORACLE_HOME/product/10.2.0/db_1 /bk/oracle_product_back

[oracle@10gpri Disk1]$ tar -cvfz /bk/oracle_backup.tar.gz $ORACLE_BASE /oradata/ora10g/*

OEM,ISQLPLUS等

[oracle@10gpri ~]$ lsnrctl stop

[oracle@10gpri ~]$ emctl stop dbconsole

[oracle@10gpri ~]$ isqlplusctl stop

将p8202632_10205_LINUX.zip上传到/bk并解压:

[oracle@10gpri bk]$ ls Disk1/

install patch_note.htm response runInstaller stage

[oracle@10gpri Disk1]$ export LANG=en

控制X server访问权限

[root@10gpri ~]# xhost +

access control disabled, clients can connect from any host

[root@10gpri ~]# su – oracle

,开启安装OUI界面

[oracle@10gpri Disk1]$ ./runInstaller

Starting Oracle Universal Installer...

Checking installer requirements...

Checking operating system version: must be redhat-3, SuSE-9, SuSE-10, redhat-4, redhat-5, redhat-6, UnitedLinux-1.0, asianux-1, asianux-2, asianux-3, enterprise-4, enterprise-5 or SuSE-11 Passed

All installer requirements met.

Preparing to launch Oracle Universal Installer from /tmp/OraInstall2011-08-26_10-34-03AM. Please wait ...[oracle@10gpri Disk1]$ Oracle Universal Installer, Version 10.2.0.5.0 Production

Copyright (C) 1999, 2010, Oracle. All rights reserved.

出现OUI图形界面如下:

clip_image002_thumb[7]

点击 ”Next”,进入选择oracle_home界面:

clip_image004_thumb[5]

只有一个数据库的话默认即可,接着点击 “Next”,出现如下对话框:

clip_image005_thumb[3]

由于之前安装过数据库软件,所以这里提示安装目的目录非空,是否覆盖,点击”Yes”即可:

clip_image007_thumb[3]

填写一个邮箱地址,取消第二项的对钩,继续点击 ”Next”,出现下图:

clip_image008_thumb[4]

打上对钩,点击 ”Continue”,出现下图示:

clip_image010_thumb[3]

检查系统参数配置通过,点击 “Next”,如下:

clip_image012_thumb[2]

点击 “Install”按钮,开始安装升级数据库软件,过程如下图所示:

clip_image014_thumb[2]

安装完成后,会出现如下一个对话框:

clip_image015_thumb[3]

按照上面对话框的要求,打开另一个终端,以root身份登录,执行脚本/u01/oracle/product/10.2.0/db_1/root.sh,该脚本会提示是否覆盖已存在的目录,默认为否即可。

再回到刚才的终端,点击”OK”按钮,弹出如下界面:

clip_image017_thumb[3]

此时提示版本升级已经成功,点击 ”Exit”按钮,退出即可。

至此,数据库软件产品升级已经完成。

[oracle@10gpri Disk1]$ sqlplus / as sysdba

SQL> startup upgrade;

SQL> select tablespace_name, sum(bytes)/(1024*1024) "Free M" from dba_free_space where tablespace_name = 'SYSTEM' group by tablespace_name;

TABLESPACE_NAME Free M

------------------------------ ----------

SYSTEM 10.375

SQL> SPOOL patch.log

SQL>@?/rdbms/admin/catupgrd.sql //此脚本执行时间大概需要20分钟左右

Total Upgrade Time: 00:24:46 //设置JAVA_POOL_SIZE为150M时的升级所用时间

Total Upgrade Time: 01:06:39 //不设置JAVA_POOL_SIZE为150M时的升级所用时间,所以,大家一定要记得设置这个参数啊!!

SQL>SPOOL OFF

SQL>shutdown immediate

SQL> startup

SQL> @?/rdbms/admin/utlrp.sql

SQL> @?/rdbms/admin/catalog.sql;

SQL> @?/rdbms/admin/catproc.sql;

SQL> shutdown immediate;

SQL> startup

SQL> select owner,object_name,subobject_name,object_type,status from dba_objects where status<>'VALID';

SQL> select status from v$instance;

SQL> select * from v$version;

SQL> col comp_name format a30

SQL>col version format a30

SQL>col status format a10

SQL> SELECT comp_name, version, status FROM dba_registry;

SQL>select username from dba_users;

SQL> quit

及ISQLPLUS

[oracle@10gpri Disk1]$ emctl start dbconsole

[oracle@10gpri Disk1]$ isqlplusctl start

[oracle@10gpri Disk1]$ lsnrctl start

(IE方式访问OEM)

(IE方式访问isqlplus)

/dba (IE方式访问isqlplus dba)

以上升级操作可以总结为以下几个要点:

如果是全新安装的数据库,直接运行补丁包就可以了

p8202632_10205_LINUX.zip

./runInstaller

如果是已经创建了数据库,并且有应用在上面,则先停止相关应用

再按以下步骤执行:

0)shutdown 数据库,并停止所有oracle相关的服务和stop listener .

$ isqlplusctl stop

$ emctl stop dbconsole

$ lsnrctl stop

注意: 需要停止Distributed Transaction Coordinator服务/iis服务/web publish(www)/;

1)冷备份数据库

2)运行安装补丁程序

3)startup upgrade; lsnrctl start

3.1)修改java_pool_size / large_pool_size=150M

SQL> ALTER SYSTEM SET JAVA_POOL_SIZE=’150M’ SCOPE=spfile;

SQL>spool upgrd.log

4)运行脚本

SQL>@?/rdbms/admin/catupgrd.sql

SQL>spool off

5)shutdown immediate

6)startup

7)运行脚本

SQL>@?/rdbms/admin/utlrp.sql;

SQL>@?/rdbms/admin/catalog.sql;

SQL>@?/rdbms/admin/catproc.sql;

8)察看数据库安装的组件、版本、状态:

col comp_name format a30

col version format a30

col status format a10

SELECT comp_name, version, status FROM dba_registry;

如果升级失败,可以尝试回退机制

SQL>startup downgrade

SQL>spool downgrade.log

SQL>@catdwgrd.sql (10.2.0.1运行的是这个,而10.1降级用的是d92000.sql,即dold_release.sql)

SQL>spool off

SQL>shutdown immediate

阅读(1870) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~