iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >AIX环境文件系统迁移到ASM存储
  • 152
分享到

AIX环境文件系统迁移到ASM存储

2024-04-02 19:04:59 152人浏览 泡泡鱼
摘要

AIX环境文件系统迁移到ASM存储系统环境:操作系统:AIX5.3-08Oracle:  Oracle 10gR2一、构建ASM 存储环境http://tiany.blog.51cto.com/5

AIX环境文件系统迁移到ASM存储

系统环境:

操作系统:AIX5.3-08

Oracle:  Oracle 10gR2


一、构建ASM 存储环境

http://tiany.blog.51cto.com/513694/1418564

oracle DataBase单实例使用ASM案例(4)--aiX系统Oracle 10g应用

二、迁移文件系统到ASM

1、查看ASM Instance

[oracle@aix211 ~]$export ORACLE_SID=+ASM

[oracle@aix211 ~]$!sql

sqlplus '/as sysdba'

SQL*Plus: Release 10.2.0.1.0 - Production on Thu May 29 17:23:24 2014

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

Connected to an idle instance.

SQL> startup

ASM instance started

Total System Global Area  130023424 bytes

Fixed Size                  2019136 bytes

Variable Size             102838464 bytes

ASM Cache                  25165824 bytes

ASM diskgroups mounted

SQL> select name ,state from v$asm_diskgroup;

NAME                           STATE

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

DG1                            MOUNTED

RCY1                           MOUNTED


SQL> 

2、修改实例参数

SQL> alter system set db_create_file_dest ='+dg1' scope=spfile;

System altered.

SQL> show parameter control

NAME                                 TYPE        VALUE

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

control_file_record_keep_time        integer     7

control_files                        string      /u01/app/oracle/oradata/prod/c

                                                 ontrol01.ctl, /dsk1/oradata/pr

                                                 od/control02.ctl

SQL> alter system set control_files='+dg1' scope=spfile;

System altered.

3、转储控制文件到控制文件

RMAN> shutdown immediate;

database closed

database dismounted

Oracle instance shut down

RMAN> startup nomount;

connected to target database (not started)

Oracle instance started

Total System Global Area    1258291200 bytes


Fixed Size                     2020552 bytes

Variable Size                318769976 bytes

Database Buffers             922746880 bytes

Redo Buffers                  14753792 bytes

RMAN> restore controlfile from '/u01/app/oracle/oradata/prod/control01.ctl';

Starting restore at 29-MAY-14

allocated channel: ORA_DISK_1

channel ORA_DISK_1: sid=156 devtype=DISK

channel ORA_DISK_1: copied control file copy

output filename=+DG1/prod/controlfile/backup.256.848857069

Finished restore at 29-MAY-14

4、转储数据文件到ASM磁盘组

RMAN> alter database mount;

database mounted

released channel: ORA_DISK_1

RMAN> backup as copy database format '+dg1';

Starting backup at 29-MAY-14

allocated channel: ORA_DISK_1

channel ORA_DISK_1: sid=156 devtype=DISK

channel ORA_DISK_1: starting datafile copy

input datafile fno=00001 name=/u01/app/oracle/oradata/prod/system01.dbf

output filename=+DG1/prod/datafile/system.257.848857161 tag=TAG20140529T173920 recid=12 stamp=848857281

channel ORA_DISK_1: datafile copy complete, elapsed time: 00:02:05

channel ORA_DISK_1: starting datafile copy

input datafile fno=00003 name=/u01/app/oracle/oradata/prod/sysaux01.dbf

output filename=+DG1/prod/datafile/sysaux.258.848857287 tag=TAG20140529T173920 recid=13 stamp=848857355

channel ORA_DISK_1: datafile copy complete, elapsed time: 00:01:15

channel ORA_DISK_1: starting datafile copy

input datafile fno=00005 name=/u01/app/oracle/oradata/prod/example01.dbf

output filename=+DG1/prod/datafile/example.259.848857363 tag=TAG20140529T173920 recid=14 stamp=848857404

channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:45

channel ORA_DISK_1: starting datafile copy

input datafile fno=00002 name=/u01/app/oracle/oradata/prod/undotbs01.dbf

output filename=+DG1/prod/datafile/undotbs1.260.848857407 tag=TAG20140529T173920 recid=15 stamp=848857434

channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:35

channel ORA_DISK_1: starting datafile copy

input datafile fno=00004 name=/u01/app/oracle/oradata/prod/users01.dbf

output filename=+DG1/prod/datafile/users.261.848857443 tag=TAG20140529T173920 recid=16 stamp=848857457

channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:25

Finished backup at 29-MAY-14

Starting Control File and SPFILE Autobackup at 29-MAY-14

piece handle=/backup/c-259825570-20140529-01 comment=NONE

Finished Control File and SPFILE Autobackup at 29-MAY-14

RMAN> switch database to copy;

datafile 1 switched to datafile copy "+DG1/prod/datafile/system.257.848857161"

datafile 2 switched to datafile copy "+DG1/prod/datafile/undotbs1.260.848857407"

datafile 3 switched to datafile copy "+DG1/prod/datafile/sysaux.258.848857287"

datafile 4 switched to datafile copy "+DG1/prod/datafile/users.261.848857443"

datafile 5 switched to datafile copy "+DG1/prod/datafile/example.259.848857363"

5、恢复数据库

RMAN> recover database;

Starting recover at 29-MAY-14

using channel ORA_DISK_1

starting media recovery

media recovery complete, elapsed time: 00:00:00

Finished recover at 29-MAY-14

RMAN> alter database open;

database opened

6、迁移临时表空间

SQL> select name from v$datafile;

NAME

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

+DG1/prod/datafile/system.257.848857161

+DG1/prod/datafile/undotbs1.260.848857407

+DG1/prod/datafile/sysaux.258.848857287

+DG1/prod/datafile/users.261.848857443

+DG1/prod/datafile/example.259.848857363

SQL> select name from v$tempfile;

NAME

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

/u01/app/oracle/oradata/prod/temp01.dbf

SQL> alter tablespace temp add tempfile '+dg1';

Tablespace altered.

SQL> select name from v$tempfile;

NAME

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

/u01/app/oracle/oradata/prod/temp01.dbf

+DG1/prod/tempfile/temp.262.848858041

SQL> alter tablespace temp drop tempfile '/u01/app/oracle/oradata/prod/temp01.dbf';

Tablespace altered.

SQL> select name from v$tempfile;

NAME

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

+DG1/prod/tempfile/temp.262.848858041

7、迁移redo日志组

SQL> set linesize 120

SQL> select * from v$log


    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         1          1        114   52428800          2 YES INACTIVE                989355 29-MAY-14

         2          1        115   52428800          2 YES INACTIVE                989368 29-MAY-14

         3          1        113   52428800          2 YES INACTIVE                988986 29-MAY-14

         4          1        116   52428800          2 NO  CURRENT                 989387 29-MAY-14


SQL> col member for a50

SQL> select group#,member from v$logfile;

    GROUP# MEMBER

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

         3 /dsk1/oradata/prod/redo03a.log

         2 /dsk1/oradata/prod/redo02a.log

         1 /dsk1/oradata/prod/redo01a.log

         1 /dsk2/oradata/prod/redo01b.log

         2 /dsk2/oradata/prod/redo02b.log

         3 /dsk2/oradata/prod/redo03b.log

         4 /dsk1/oradata/prod/redo04a.log

         4 /dsk2/oradata/prod/redo04b.log

8 rows selected.

添加新的日志组到ASM diskgroup:

SQL> alter database add logfile  

  2  ('+dg1','+rcy1') size 10m;


SQL> alter database add logfile

  2  ('+dg1','+rcy1') size 10m;


SQL> select * from v$log;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         1          1        114   52428800          2 YES INACTIVE                989355 29-MAY-14

         2          1        115   52428800          2 YES INACTIVE                989368 29-MAY-14

         3          1        113   52428800          2 YES INACTIVE                988986 29-MAY-14

         4          1        116   52428800          2 NO  CURRENT                 989387 29-MAY-14

         5          1          0   10485760          2 YES UNUSED                       0

         6          1          0   10485760          2 YES UNUSED                       0


6 rows selected.

SQL> select group#,member from v$logfile order by 1;

    GROUP# MEMBER

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

         1 /dsk1/oradata/prod/redo01a.log

         1 /dsk2/oradata/prod/redo01b.log

         2 /dsk1/oradata/prod/redo02a.log

         2 /dsk2/oradata/prod/redo02b.log

         3 /dsk1/oradata/prod/redo03a.log

         3 /dsk2/oradata/prod/redo03b.log

         4 /dsk1/oradata/prod/redo04a.log

         4 /dsk2/oradata/prod/redo04b.log

         5 +RCY1/prod/onlinelog/group_5.256.848858217

         5 +DG1/prod/onlinelog/group_5.263.848858213

         6 +RCY1/prod/onlinelog/group_6.257.848858259


    GROUP# MEMBER

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

         6 +DG1/prod/onlinelog/group_6.264.848858253

12 rows selected.

SQL> select * from v$log;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         1          1        114   52428800          2 YES INACTIVE                989355 29-MAY-14

         2          1        115   52428800          2 YES INACTIVE                989368 29-MAY-14

         3          1        113   52428800          2 YES INACTIVE                988986 29-MAY-14

         4          1        116   52428800          2 YES ACTIVE                  989387 29-MAY-14

         5          1        117   10485760          2 YES ACTIVE                  990481 29-MAY-14

         6          1        118   10485760          2 NO  CURRENT                 990483 29-MAY-14

6 rows selected.

删除旧的日志组:

SQL> alter database drop logfile group 1;

Database altered.

SQL> alter database drop logfile group 2;

Database altered.

SQL> alter database drop logfile group 3;

Database altered.

SQL> alter system checkpoint;

System altered.

SQL> select * from v$log;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         4          1        119   52428800          2 YES ACTIVE                  990548 29-MAY-14

         5          1        120   10485760          2 NO  CURRENT                 990566 29-MAY-14

         6          1        118   10485760          2 YES INACTIVE                990483 29-MAY-14

SQL> alter system switch logfile;

System altered.

SQL> select * from v$log;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         4          1        119   52428800          2 YES INACTIVE                990548 29-MAY-14

         5          1        120   10485760          2 NO  ACTIVE                  990566 29-MAY-14

         6          1        121   10485760          2 NO  CURRENT                 991692 29-MAY-14

SQL> alter database drop logfile group 4;

Database altered.

SQL> select * from v$log;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM

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

         5          1        122   10485760          2 NO  CURRENT                 991711 29-MAY-14

         6          1        121   10485760          2 YES INACTIVE                991692 29-MAY-14

SQL> select group#,member from v$logfile order by 1;

    GROUP# MEMBER

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

         5 +DG1/prod/onlinelog/group_5.263.848858213

         5 +RCY1/prod/onlinelog/group_5.256.848858217

         6 +DG1/prod/onlinelog/group_6.264.848858253

         6 +RCY1/prod/onlinelog/group_6.257.848858259

调整recover area参数:

SQL> show parameter recover

NAME                                 TYPE        VALUE

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

db_recovery_file_dest                string

db_recovery_file_dest_size           big integer 0

recovery_parallelism                 integer     0

SQL> alter system set db_recovery_file_dest='+rcy1' scope=spfile;

System altered.

SQL> alter system set db_recovery_file_dest_size=2g scope=spfile;

System altered.

8、删除文件系统下的原数据文件

[oracle@aix211 ~]$cd /u01/app/oracle/oradata/prod/

[oracle@aix211 prod]$ls

control01.ctl  example01.dbf  sysaux01.dbf   system01.dbf   undotbs01.dbf  users01.dbf

[oracle@aix211 prod]$rm *

[oracle@aix211 prod]$ls

[oracle@aix211 prod]$

对于spfile参数可以存储在文件系统或ASM磁盘组上:

SQL> show parameter pfile;

NAME                                 TYPE        VALUE

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

spfile                               string      /u01/app/oracle/product/10.2.0

                                                 /db_1/dbs/spfileprod.ora

@至此,在AIX下迁移文件系统到ASM磁盘组工作完成,通过ASM存储,数据库读写性能得到了一定的提升。

附注:

Oracle官方文档提供的redo日志组迁移脚本

Example 8-1 Migrating the online redo logs


SET SERVEROUTPUT ON;

DECLARE

   CURSOR rlc IS

      SELECT GROUP# GRP, THREAD# THR, BYTES, 'NO' SRL

      FROM   V$LOG

      UNION

      SELECT GROUP# GRP, THREAD# THR, BYTES, 'YES' SRL

      FROM   V$STANDBY_LOG

      ORDER BY 1;

   stmt     VARCHAR2(2048);

BEGIN

   FOR rlcRec IN rlc LOOP

      IF (rlcRec.srl = 'YES') THEN

         stmt := 'ALTER DATABASE ADD STANDBY LOGFILE THREAD ' ||

                 rlcRec.thr || ' SIZE ' || rlcRec.bytes;

         EXECUTE IMMEDIATE stmt;

         stmt := 'ALTER DATABASE DROP STANDBY LOGFILE GROUP ' || rlcRec.grp;

         EXECUTE IMMEDIATE stmt;

      ELSE

         stmt := 'ALTER DATABASE ADD LOGFILE THREAD ' ||

                 rlcRec.thr || ' SIZE ' ||  rlcRec.bytes;

         EXECUTE IMMEDIATE stmt;

         BEGIN

            stmt := 'ALTER DATABASE DROP LOGFILE GROUP ' || rlcRec.grp;

            DBMS_OUTPUT.PUT_LINE(stmt);

            EXECUTE IMMEDIATE stmt;

         EXCEPTION

            WHEN OTHERS THEN

               EXECUTE IMMEDIATE 'ALTER SYSTEM SWITCH LOGFILE';

               EXECUTE IMMEDIATE 'ALTER SYSTEM CHECKPOINT GLOBAL';

               EXECUTE IMMEDIATE stmt;

         END;

      END IF;

   END LOOP;

END;

/


您可能感兴趣的文档:

--结束END--

本文标题: AIX环境文件系统迁移到ASM存储

本文链接: https://www.lsjlt.com/news/44630.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-15
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-15
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-15
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-15
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-15
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-15
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-15
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-15
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作