当前位置:  数据库>oracle

恢复db_recovery_file_dest_size参数为默认值“0”方法

    来源: 互联网  发布时间:2017-05-04

    本文导语: db_recovery_file_dest_size参数的作用是限制闪回恢复区可存放文件总大小。一旦将参数db_recovery_file_dest_size设置为非零值后“很难”恢复为默认值“0”。这里我给出两种可以将此参数恢复为默认值“0”的方法,一种是“迂回策略”,...

db_recovery_file_dest_size参数的作用是限制闪回恢复区可存放文件总大小。一旦将参数db_recovery_file_dest_size设置为非零值后“很难”恢复为默认值“0”。这里我给出两种可以将此参数恢复为默认值“0”的方法,一种是“迂回策略”,一种是reset方法。

1.查看默认情况下db_recovery_file_dest_size参数值


db_recovery_file_dest_size参数的默认值是“0”。
SYS@PROD> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- -------------
db_recovery_file_dest_size           big integer 0

SYS@PROD> col name for a20
SYS@PROD> select * from v$recovery_file_dest;

NAME  SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES
----- ----------- ---------- ----------------- ---------------
                0          0                 0               0

2.将db_recovery_file_dest_size参数调整为非零值

SYS@PROD> alter system set db_recovery_file_dest_size=4g;

System altered.

SYS@PROD> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------
db_recovery_file_dest_size           big integer 4G
SYS@PROD> select * from v$recovery_file_dest;

NAME  SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES
----- ----------- ---------- ----------------- ---------------
       4294967296          0                 0               0

3.尝试将db_recovery_file_dest_size参数修改为“0”
SYS@PROD> alter system set db_recovery_file_dest_size=0;
alter system set db_recovery_file_dest_size=0
*
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-19803: Parameter DB_RECOVERY_FILE_DEST_SIZE is out of range (1 -
18446744073709551614)

  报错信息非常显然,db_recovery_file_dest_size参数大小必须介于1~18446744073709551614之间,也就是说不可以调整为其默认值“0”。

  有朋友说,是不是可以尝试使用scope=spfile方式调整此参数。注意,也是不可以的。验证如下。
SYS@PROD> alter system set db_recovery_file_dest_size=0 scope=spfile;

System altered.

  此处貌似修改成功,但是这样调整后数据库将无法重新启动,报错信息如下。
SYS@PROD> startup;
ORA-19803: Parameter DB_RECOVERY_FILE_DEST_SIZE is out of range (1 - 18446744073709551614)

  一样的报错原因,db_recovery_file_dest_size参数大小必须介于1~18446744073709551614之间。

4.迂回处理方法
  既然使用常规方法无法达到我们将db_recovery_file_dest_size参数调整为“0”的目的,那我们应该如何应对这个需求呢。
  经过尝试,可以通过pfile迂回的达到恢复的目的。
1)使用当前的spfile生成pfile
SYS@PROD> create pfile from spfile;

File created.

2)使用vi命令将pfile中的db_recovery_file_dest_size参数信息删除掉
[Oracle@secdb1 ~]$ vi $ORACLE_HOME/dbs/initPROD.ora
……
*.db_recovery_file_dest_size=4294967296
……

  注:如果经过上面scope=spfile方法调整过的话,pfile中的信息如下:
*.db_recovery_file_dest_size=0
  方法是一样的,将整行信息删除掉。

3)停止数据库并生成spfile,并用spfile启动数据库
SYS@PROD> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SYS@PROD> create spfile from pfile;

File created.

SYS@PROD> startup;
ORACLE instance started.

Total System Global Area  314572800 bytes
Fixed Size                  1219184 bytes
Variable Size             109053328 bytes
Database Buffers          201326592 bytes
Redo Buffers                2973696 bytes
Database mounted.
Database opened.

4)查看修改成果
SYS@PROD> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- -----------
db_recovery_file_dest_size           big integer 0

SYS@PROD> col name for a20
SYS@PROD> select * from v$recovery_file_dest;

NAME   SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES
------ ----------- ---------- ----------------- ---------------
                 0          0                 0               0
目的达到。

5.使用直截了当的reset方法
恢复参数为默认值的另外一种便捷方法是使用reset方法,可以避免上面的“迂回策略”,调整过程展示如下,供各位朋友参考。
SYS@PROD> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- --------
db_recovery_file_dest_size           big integer 4G

SYS@PROD> alter system reset db_recovery_file_dest_size scope=spfile sid='*';

System altered.

SYS@PROD> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SYS@PROD> startup;
ORACLE instance started.

Total System Global Area  314572800 bytes
Fixed Size                  1219184 bytes
Variable Size             109053328 bytes
Database Buffers          201326592 bytes
Redo Buffers                2973696 bytes
Database mounted.
Database opened.
SYS@PROD> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- ----------
db_recovery_file_dest_size           big integer 0































6.小结
  本文通过实验的方式探索出了一种恢复数据库参数为默认值的方法。请朋友们从原理上去理解这个过程,参数文件的根本作用就是“覆盖参数的默认值”,以便刻画出一个最适合自己应用场景的环境。因此参数文件中记录的都是与默认参数值不一样的内容。因此通过删除pfile参数文件中的的参数,便可达到恢复参数为其默认值的目的。BTW,使用reset方法更加快速便捷。











































































































    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Python namedtuple对象json序列化/反序列化及对象恢复
  • OpenLDAP 的数据库文件坏了,怎么恢复? (从LDIF文件恢复) ??? 急啊.....
  • 如何进行MongoDB自动备份增量备份和恢复
  • Ext4文件恢复工具 giis-ext4
  • Windows文件恢复工具 Recuva
  • linux如何恢复系统
  • unix下怎样恢复被删除的文件?
  • Linux文件恢复工具 gET iT i sAY
  • MySQL数据库备份恢复程序 MySQLDumper
  • oracle drop table(表)数据恢复方法
  • 请问用rm 命令删掉的目录(含文件)有什么办法恢复?
  • 用rm命令删除文件后,无法恢复吗
  • 我在redhat 7.0下删除了整个目录,能不能恢复?
  • 误删了文件!如何恢复呀!急!急!在线等!
  • 磁盘恢复工具 PhotoRec
  • 磁盘管理及数据恢复软件 DiskGenius
  • 如何在客户端恢复FTP服务器(UNIX)被删除的文件???
  • Drupal 恢复工具 Drupowa
  • 谁能帮我!错手把逻辑盘的东西删了,能不能恢复。
  • 恢复启动列表?
  • 如何恢复引导redhat7.2


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,