ORACLE10gRAC数据库迁移至10gRAC
1、数据库备份
RUN {
ALLOCATE CHANNEL ch00 DEVICE TYPE disk;
ALLOCATE CHANNEL ch01 DEVICE TYPE disk;
ALLOCATE CHANNEL ch02 DEVICE TYPE disk;
ALLOCATE CHANNEL ch03 DEVICE TYPE disk;
ALLOCATE CHANNEL ch04 DEVICE TYPE disk;
ALLOCATE CHANNEL ch05 DEVICE TYPE disk;
backup as compressed backupset database filesperset 5 format '/backup/bk_%d_%T%s_%p' ;
sql 'alter system archive log current';
backup current controlfile format '/backup/ctl_%d_%T_%s';
RELEASE CHANNEL ch00;
RELEASE CHANNEL ch01;
RELEASE CHANNEL ch02;
RELEASE CHANNEL ch03;
RELEASE CHANNEL ch04;
RELEASE CHANNEL ch05;
}
备份完成后多切换几次redo日志
2、数据库恢复
一 检验条件
二 准备工作
拷贝备份文件到目标服务器:scp -r backup/ 10.168.39.243:/backup
1 创建相关目录
两节点
mkdir -p /oracle/admin/orcl/adump
mkdir -p /oracle/admin/orcl/bdump
mkdir -p /oracle/admin/orcl/cdump
mkdir -p /oracle/admin/orcl/udump
mkdir -p /oracle/admin/orcl/pfile
mkdir -p /oracle/arch
节点1
mkdir /rac_arch1
chown -R oracle:oinstall /rac_arch1/
chmod -R 775 /rac_arch1/
节点2
mkdir /rac_arch2
chown -R oracle:oinstall /rac_arch2/
chmod -R 775 /rac_arch2/
2参数文件
使用oracle用户
vi pfile0928.ora
orcl2.__db_cache_size=1090519040
orcl1.__db_cache_size=1140850688
orcl1.__java_pool_size=16777216
orcl2.__java_pool_size=16777216
orcl1.__large_pool_size=16777216
orcl2.__large_pool_size=33554432
orcl2.__shared_pool_size=402653184
orcl1.__shared_pool_size=369098752
orcl1.__streams_pool_size=16777216
orcl2.__streams_pool_size=16777216
*.audit_file_dest='/oracle/admin/orcl/adump'
*.background_dump_dest='/oracle/admin/orcl/bdump'
*.cluster_database_instances=2
*.cluster_database=true
*.compatible='10.2.0.5.0'
*.control_files='+ORCLDATA/orcl/controlfile/current01.ctl','+ORCLDATA/orcl/controlfile/current02.ctl','+ORCLDATA/orcl/controlfile/current03.ctl'
*.core_dump_dest='/oracle/admin/orcl/cdump'
*.cursor_sharing='FORCE'
*.db_block_size=8192
*.db_create_file_dest='+ORCLDATA'
*.db_domain=''
*.db_file_multiblock_read_count=16
*.db_name='orcl'
*.db_writer_processes=2
*.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)'
orcl2.instance_number=2
orcl1.instance_number=1
*.job_queue_processes=10
orcl1.local_listener='(ADDRESS=(PROTOCOL=TCP)(HOST=10.168.39.242)(PORT=1521))'
orcl2.local_listener='(ADDRESS=(PROTOCOL=TCP)(HOST=10.168.39.244)(PORT=1521))'
#orcl1.log_archive_dest_1='location=/rac_arch1'
#orcl2.log_archive_dest_1='location=/rac_arch2'
*.log_archive_dest_1='location=/backup'
*.open_cursors=300
*.optimizer_index_caching=95
*.optimizer_index_cost_adj=5
*.optimizer_mode='FIRST_ROWS_10'
*.pga_aggregate_target=3359637504
*.processes=1000
orcl1.processes=1500
orcl2.processes=1500
*.remote_listener='LISTENERS_ORCL'
*.remote_login_passwordfile='exclusive'
orcl1.sessions=1655
orcl2.sessions=1655
*.sga_target=1610612736
orcl2.thread=2
orcl1.thread=1
*.undo_management='AUTO'
orcl2.undo_tablespace='UNDOTBS2'
orcl1.undo_tablespace='UNDOTBS1'
*.user_dump_dest='/oracle/admin/orcl/udump'
三 启动实例
$ export ORACLE_SID=orcl1
sqlplus / as sysdba
startup nomount pfile='/oracle/pfile0928.ora'
四 恢复控制文件
rman target /
set dbid=1340406187
restore controlfile from '/backup/ctl_ORCL_20150928_7830';
六 恢复数据库
alter database mount;
run {
ALLOCATE CHANNEL ch00 DEVICE TYPE disk;
ALLOCATE CHANNEL ch01 DEVICE TYPE disk;
ALLOCATE CHANNEL ch02 DEVICE TYPE disk;
ALLOCATE CHANNEL ch03 DEVICE TYPE disk;
restore database;
RELEASE CHANNEL ch00;
RELEASE CHANNEL ch01;
RELEASE CHANNEL ch02;
RELEASE CHANNEL ch03;
}
注册归档日志:
catalog archivelog '/backup_243/1_24712_812625454.dbf';
catalog archivelog '/backup_243/1_24713_812625454.dbf';
catalog archivelog '/backup_243/1_24714_812625454.dbf';
catalog archivelog '/backup_243/1_24715_812625454.dbf';
catalog archivelog '/backup_243/1_24716_812625454.dbf';
catalog archivelog '/backup_243/2_22519_812625454.dbf';
catalog archivelog '/backup_243/2_22520_812625454.dbf';
catalog archivelog '/backup_243/2_22521_812625454.dbf';
catalog archivelog '/backup_243/2_22522_812625454.dbf';
catalog archivelog '/backup_243/2_22523_812625454.dbf';
run {
ALLOCATE CHANNEL ch00 DEVICE TYPE disk;
ALLOCATE CHANNEL ch01 DEVICE TYPE disk;
ALLOCATE CHANNEL ch02 DEVICE TYPE disk;
ALLOCATE CHANNEL ch03 DEVICE TYPE disk;
recover database;
RELEASE CHANNEL ch00;
RELEASE CHANNEL ch01;
RELEASE CHANNEL ch02;
RELEASE CHANNEL ch03;
}
六 打开数据库
SQL> alter database open resetlogs;
七 数据库整理
修改spfile启动 shutdown immediate
create spfile='+ORCLDATA/orcl/SPFILE/spfileorcl.ora' from pfile='/oracle/product/10.2.0/db_1/dbs/initorcl1.ora';
echo "SPFILE='+ORCLDATA/orcl/SPFILE/spfileorcl.ora'" > /oracle/product/10.2.0/db_1/dbs/initorcl1.ora
startup
show parameter spfile
八、启用集群特性:
select * from v$option where parameter = 'Real Application Clusters';
show parameter cluster
alter system set cluster_database=true scope=spfile;
alter system set cluster_database_instances=2 scope=spfile;
alter system set instance_number=1 scope=spfile sid='orcl1';
alter system set instance_number=2 scope=spfile sid='orcl2';
alter system set thread=1 scope=spfile sid='orcl1';
alter system set thread=2 scope=spfile sid='orcl2';
新建一组UNDO 表空间和线程2 使用的两组REDO 文件:这里已经创建。
alter database enable thread 2;
修改归档路径为两个节点:
alter system set log_archive_dest_1='location=/arch1' scope=spfile sid='orcl1';
alter system set log_archive_dest_1='location=/arch2' scope=spfile sid='orcl2';
节点2
export ORACLE_SID=orcl2
echo "SPFILE='+ORCLDATA/orcl/SPFILE/spfileorcl.ora'" > /oracle/product/10.2.0/db_1/dbs/initorcl2.ora
sqlplus / as sysdba
startup
set line 150 pages 1000
show parameter cluster;
select instance_number,instance_name,host_name from v$instance;
select instance_number,instance_name,host_name from gv$instance;
注册到OCR
srvctl add database -d orcl -o $ORACLE_HOME -p +ORCLDATA/orcl/SPFILE/spfileorcl.ora
srvctl add instance -d orcl -i orcl1 -n hostname1
srvctl add instance -d orcl -i orcl2 -n hostname2
srvctl start database -d orcl
监听 、tnsnames.ora
alter system set local_listener='(ADDRESS = (PROTOCOL = TCP)(HOST =10.168.34.243)(PORT = 1521))' scope=both sid='orcl1';
alter system set local_listener='(ADDRESS = (PROTOCOL = TCP)(HOST =10.168.34.245)(PORT = 1521))' scope=both sid='orcl2';
tnsnames.ora
LISTENERS_ORCL =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname1-vip)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname2-vip)(PORT = 1521))
)
ORCL2 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname2-vip)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
(INSTANCE_NAME = orcl2)
)
)
ORCL1 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname1-vip)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
(INSTANCE_NAME = orcl1)
)
)
ORCL =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname1-vip)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = hostname2-vip)(PORT = 1521))
(LOAD_BALANCE = yes)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)
修改SGA PGA 以sys用户登录系统
alter system set sga_max_size=30000m scope=spfile sid='*';
alter system set sga_target=30000m scope=spfile sid='*';
alter system set pga_aggregate_target=8000m scope=spfile sid='*';
重启数据库
show parameter 查看
sqlplus / as sysdba
alter system set sga_max_size=3500m scope=spfile
alter system set sga_target=3000m scope=spfile
alter system set pga_aggregate_target=1500m scope=spfile;
shutdown immediate
startup
show parameter sga
show parameter pga
拷贝生产环境密码文件到两个节点:
八、验证
select open_mode from v$database;
select instance_name,status from gv$instance;
select name,status from v$datafile;
select name ,status from v$controlfile;
select count(*) from dba_objects;
select count(*) from dba_segments;
至此RAC数据库迁移至RAC完毕。
ORACLE10gRAC数据库迁移至10gRAC的更多相关文章
- EF Code First Migrations数据库迁移
1.EF Code First创建数据库 新建控制台应用程序Portal,通过程序包管理器控制台添加EntityFramework. 在程序包管理器控制台中执行以下语句,安装EntityFramewo ...
- 2.EF中 Code-First 方式的数据库迁移
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ...
- laravel数据库迁移(三)
laravel号称世界上最好的框架,数据库迁移算上一个,在这里先简单入个门: laravel很强大,它把表中的操作写成了migrations迁移文件,然后可以直接通过迁移文件来操作表.所以 , 数据迁 ...
- Code First开发系列之数据库迁移
返回<8天掌握EF的Code First开发>总目录 本篇目录 开启并运行迁移 使用迁移API 应用迁移 给已存在的数据库添加迁移 EF的其他功能 本章小结 自我测试 本系列的源码本人已托 ...
- ABP Migration(数据库迁移)
今天准备说说EntityFramework 6.0+,它与我之前所学的4.0有所区别,自从4.1发布以来,code first 被许多人所钟爱,Dbcontext API也由此时而生.早在学校的时候就 ...
- sqlserver 2008R2数据库迁移oracle
x项目需要,将以前的sqlserver数据库迁移的oracle数据库中,由于以前对oracle只是在DML语句的步骤,所以总结一下这次遇到的问题以及具体步骤 1,oracle新建数据库 新建Oracl ...
- 【强烈推荐】数据库迁移利器:Migrator.Net
简介 很郁闷,写了一天的遇到LiveWriter错误,可恶啊 几年前在做项目中第一次接触到了Migrator.Net,就深深被吸引住了,至此以后在新的大项目中,我都会使用Migrator.Net来创建 ...
- ubuntu系统lamp环境搭建、数据库迁移、设置数据库外部访问
sudo passwd root设置两次密码su输入设置的密码exit (退出root帐号) 1.sudo apt-get update 2.sudo apt-get install apache2 ...
- Laravel学习笔记(三)数据库 数据库迁移
该章节内容翻译自<Database Migration using Laravel>,一切版权为原作者. 原作者:Stable Host, LLC 翻译作者:Bowen Huang 正文: ...
随机推荐
- jQuery method and examples
一:介绍: jQuery:是DOM和js的封装.jQuery是一个兼容多浏览器的javascript库,核心理念是write less,do more(写得更少,做得更多).现在大多数的pc端的网站都 ...
- 在 CentOS 7.x / Fedora 21 上面体验 PHP 7.0
编译自:http://linoxide.com/linux-how-to/install-php-7-centos-7-fedora-21/作者: Aun Raza原创:LCTT https://li ...
- Tomcat version 6.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 Web modules的解决办法
前提:用eclipse做项目,新建“Dynamic Web Project”时,“Dynamic web module version”栏里选了3.0版本,部署项目的时候出现了如题的错误. 解决办法: ...
- php 函数strpos()
strpos() 函数查找字符串在另一字符串中第一次出现的位置. strpos(string,find,start) 返回 从string中的start位置开始找find第一次出现的位置 注意: s ...
- 《java编程思想》读书笔记 暂停一段时间,改为上面的练习题
发现个很尴尬的现象.我一天实在看得太快了...全写下 写博客都得一晚上.. 之前因为是第一次看这么厚的书,别人都说很难,以为会看很慢的.然而,已经完全学过Java的 我感觉没啥压力,越看越快....第 ...
- pwnable echo1
最近忙的好久没有更新了,有空把之前拿来练手的CTF pwn题逐渐整理一下放出来 题目是 linux 64位程序 ,流程很简单,大致思路就是先把一个跳转的机器指令写进name的地址,然后溢出覆盖eip, ...
- NTP时间同步服务器设置
一.Window Server设置 [服务器端设置]1) 修改注册表以下键值:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\ ...
- java 中文转化为拼音
依赖架包:pinyin4j.jar package net.jeeshop.core.util; import net.sourceforge.pinyin4j.PinyinHelper; impor ...
- c#-1 数据结构 定义相关 界面交互数据 Model层
1.时间用Nullable<UInt32> 除了最初时间用DateTime TimeSpan不行. 2.其他元素也用Nullable<UInt32> 3.list集合数据绑定类 ...
- VS2010 中 Entity Framework 多数据库并存方法
选中相应数据库生成的 *.edmx文件,然后在属性中找到“自定义工具命名空间”,为每个EF数据集设置不同的命名空间,这样每个数据库生成的代码就会被隔离在不同的命名空间,即使同名类型也就不会相互影响了.