(通过文件直接复制方法)最近学习了一下oracle数据库启动原理,于是,就把在windows创建起来做测试的数据库移植到linux下使用,前几
(通过文件直接复制方法)
最近学习了一下oracle数据库启动原理,于是,就把在windows创建起来做测试的数据库
移植到linux下使用,前几天把linux移植到windows成功,但windows移植到linux碰到问题会多,
在windows用习惯人会不区分大小写,但在linux是区分的,这点务必请大家注意,下面让我们一起去这过程吧!
还是和上面讲的一样,我直接通过文件复制,把原来在windows下使用的数据库移植到linux下,
而不需要通过其他工具。
虽然此移植在实际生产用途不大,但对一个刚oracle来说,确实能从中学到很多东西,所以写
下此文以供大家参考,欢迎提出宝贵介意。
系统环境:linux 下是32 位平台,linux内存,cpu等硬件条件和windows是一样。
如果硬件条件不一至,下面讲的数据迁移可能会碰到其他问题。
软件环境:linux平台和windows平台装的oracle软件版本是
oracle database 10g enterprise edition release 10.2.0.1.0 - prod
都是以企业版安装。
如果两边版本不一至,还没有实验过。
我粗略讲一下过程,把windows下的数据文件,控制文件,重做日志组文件,
参数文件,复到到linux下,然后把参数文件里的控制文件改成linux目录
下结构,同时使数据重新生成控制文件。详细步骤如下:
linux平台下的数据库配制如下
数据库是以文件系统管理
实例名:orcl
数据库名:orcl
oracle_base=/u01/app/oracle/
oracle_home=/u01/app/oracle/product/10.2.0/db_1
数据库文件存放位置:/u02/oradata/orcl
windows平台下的数据库配制如下
数据库是以文件系统管理
实例名:orcl
数据库名:orcl 由于数据库是从windows文件直接复制过来,所以数据库名是不能更改的
oracle_base=d:\oracle
oracle_home=d:\oracle\product\10.2.0\db_1
oracle_sid=orcl
数据库文件存放位置:d:\oracle\oradata\orcl
步骤如下:
--登录到windows下数据库
c:\>sqlplus / as sysdba
sql*plus: release 10.2.0.1.0 - production on 星期二 7月 1 14:53:23 2008
copyright (c) 1982, 2005, oracle. all rights reserved.
连接到:
oracle database 10g enterprise edition release 10.2.0.1.0 - production
with the partitioning, olap and data mining options
--创建参数pfile文件
sql> create pfile='initorcl.ora' from spfile;
文件已创建。
--关毕数据库
sql> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
oracle 例程已经关闭。
linux平台如输入如下创建文件夹
mkdir -o /u02/oradata/orcl
复制参数文件,控制文件,数据文件,重做日志组文件到linux平台下的目录,
我这里是在linux开了一个samba服务,然后把/u02/oradata/orcl文件夹共享
也可以在linux开个ftp,通过ftp把文件传到linux机器上
windows平台数据文件,,,重做日志组文件和控制文件放在 d:\oracle\oradata\orcl
linux平台下的数据文件 /u02/oradata/orcl
linux平台下的实例参数文件window平台下的 d:\oracle\product\10.2.0\db_1\database\initorcl.ora
复制到linux平台下的目录
/u01/app/oracle/product/10.2.0/db_1/dbs/initorcl.ora
注意这里的文件名,linux下文件名是区分大小写的,所以把全部改成小写的
以下是linux平台输入如下命令来创建文件夹:
mkdir -p /u01/app/oracle/admin/orcl/adump
mkdir -p /u01/app/oracle/admin/orcl/bdump
mkdir -p /u01/app/oracle/admin/orcl/cdump
mkdir -p /u01/app/oracle/admin/orcl/dpdump
mkdir -p /u01/app/oracle/admin/orcl/pfile
mkdir -p /u01/app/oracle/admin/orcl/udump
如果/u01/app/oracle/flash_recovery_area也不存在,也创建
mkdir -p /u01/app/oracle/flash_recovery_area
设计环境变量
set oracle_sid=linux
或者更改oracle用户下的.bash_profile文件
oracle_sid=orcl; export oracle_sid
把oracle_sid改成orcl
用vi打开文件/u01/app/oracle/product/10.2.0/db_1/dbs/initorcl.ora
把windows下的目录结构改成linux下的目录结构。
注意下,在linux下文件名和文件夹都是区分大小写的,请确保下面参数实际文件名大小写一至,否则就起动不了数据库。
下面文件是我的参数文件信息。供参考:
orcl.__db_cache_size=75497472
orcl.__java_pool_size=4194304
orcl.__large_pool_size=4194304
orcl.__shared_pool_size=75497472
orcl.__streams_pool_size=4194304
*.audit_file_dest='/u01/app/oracle/admin/orcl/adump'
*.audit_trail='db'
*.background_dump_dest='/u01/app/oracle/admin/orcl/bdump'
*.compatible='10.2.0.1.0'
*.control_files='/u02/oradata/orcl/control01.ctl','/u02/oradata/orcl/control02.ctl','/u02/oradata/orcl/control03.ctl'
*.core_dump_dest='/u01/app/oracle/admin/orcl/cdump'
*.db_block_size=8192
*.db_domain=''
*.db_file_multiblock_read_count=16
*.db_name='orcl'
*.db_recovery_file_dest='/u01/app/oracle/flash_recovery_area'
*.db_recovery_file_dest_size=2147483648
*.dispatchers='(protocol=tcp) (service=orclxdb)'
*.job_queue_processes=10
*.open_cursors=300
*.pga_aggregate_target=16777216
*.processes=150
*.remote_login_passwordfile='exclusive'
*.sga_target=167772160
*.undo_management='auto'
*.undo_tablespace='undotbs1'
*.user_dump_dest='/u01/app/oracle/admin/orcl/udump'
创建密码文件
orapwd file=/u01/app/oracle/product/10.2.0/db_1/dbs/orapworcl password=
linux下登录数据库
[oracle@localhost ~]$ sqlplus / as sysdba
sql*plus: release 10.2.0.1.0 - production on mon jul 7 13:24:38 2008
copyright (c) 1982, 2005, oracle. all rights reserved.
connected to an idle instance.
sql>
--启动到mount下
sql> startup mount pfile=/u01/app/oracle/product/10.2.0/db_1/dbs/initorcl.ora;
oracle instance started.
total system global area 167772160 bytes
fixed size 1218316 bytes
variable size 88082676 bytes
database buffers 75497472 bytes
redo buffers 2973696 bytes
database mounted.
--创建一个spfile文件,下次以spfile文件启动
sql> create spfile='spfileorcl.ora' from pfile;
file created