日志移动
数据库状态  open:
步骤1:物理的将文件拷到目的目录
[oracle@localhost orcl]$ cp /opt/oracle/oradata/orcl/redo01.log to /opt/oracle/oradata/redo01.log
步骤2:修改控制文件中相应的记录
SQL>alter database rename file '/opt/oracle/oradata/orcl/redo01.log' to '/opt/oracle/oradata/redo01.log';

修改限制:只有修改的日志组不是current的状态下才能修改(建议最好将需要移动的的日志组切换到inactive的状态下)
查看日志组状态:
SQL> select group#,status from v$log;
如果都是active,或current的话,用这个命令强制写日志文件到磁盘。
SQL> alter system checkpoint; 

数据库状态  mount:
修改步骤同上:
没有修改限制,可以修改任意状态的日志组

最后强调移动日志跟数据库是否归档无关


调整日志文件大小,增删组,成员
如果日志过小,导致切换过于频繁的话,会影响数据库性能
1、查看日志组切换时间
SQL> select to_char(first_time,'yyyy-mm-dd hh24:mi:ss'),group# from v$log;

TO_CHAR(FIRST_TIME, GROUP#
------------------- ----------
2013-06-01 18:22:43     1
2013-06-02 09:08:30     2
2013-06-01 18:21:49     3

2、查看日志组大小
SQL> select bytes/(1024*1024) from v$log;
3、查看各个日志组的状态
SQL> select group#,status from v$log;
4、删除日志组(只有在inactive状态下的日志组可以删除,如果要修改的组没有在inactive状态下,那么可以用
这两个命令,调整日志组的状态
SQL> alter system switch logfile;
SQL> alter system checkpoint; 
SQL> alter database drop logfile group 3;
Database altered.
5、删除日志物理文件
SQL> ho rm /opt/oracle/oradata/orcl/redo03.log;
6、新建日志组  (如果有多个成员,括号内用逗号分隔)
SQL> alter database add logfile group 3 ('/opt/oracle/oradata/orcl/redo03.log') size 100M;
7、添加日志成员(非current状态日志组)
SQL>alter database add logfile member'/opt/oracle/oradata/orcl/redo033.log' to group 3;
8、删除日志成员(非current状态日志组)
SQL>alter database drop logfile member'/opt/oracle/oradata/orcl/redo033.log'

--------------------------------------------------------------
日志文件丢失:
--------------------------------------------------------------
只要日志文件存在就可以启动,假如日志文件丢失了,重建即可。
能有镜像日志文件最好,没有就只能重建了。
重建方法1:用clean语法(可以清空指定日志组)
重建方法2:新建日志文件
重建方法3:resetlogs打开数据库(直接清空所有日志组)


1 :如果数据库是正常关闭

查看当前日志组的状态,如果日志组2(current)丢了,清空时要加unarchived关键字,因为关闭的时候当前日志不会被归档,而且还要确保其他日志组可用,因为清空日志组2的时候,会先切换当前日志组为其他组,如果没有其他日志组可用就会报错,如果下一个日志组也不可用,就先清空其他(已丢失的且非current状态)的日志组,使其可用。最后清空current日志组。

SQL> select group#,status from v$log;
    GROUP# STATUS
---------- ----------------
1 INACTIVE
2 CURRENT
INACTIVE


SQL> alter database clear logfile '/opt/oracle/oradata/orcl/redo01.log';  
SQL> alter database clear logfile '/opt/oracle/oradata/orcl/redo03.log';  
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log';   强制清除没有归档的日志,导致之前的备份全部失效,因为有日志断点

SQL> alter database open;
Database altered

如果只是INACTIVE日志组丢失了,那么只需清空丢失的那个日志组,且不会影响之前的备份文件的恢复(不会照成日志间断,因为正常关机之前都已归档了)
如果只是CURRENT日志组丢失了,也需要清空日志组,但是之前的备份就无效了(因为当前日志没有归档,所以有日志断点)
所以如果清除了当前日志之后一定要重新做全备



2 : 如果数据库非正常关闭

2.1:丢的是inactive日志组
查看丢的日志组对应的状态,如果是inactive则可以用上面清空的方法恢复。如果丢的是active或者current,则不能用清空的方法,因为清空时需要介质恢复,然而你丢的就是介质恢复需要的文件,所以不能恢复
SQL> select group#,status from v$log;
    GROUP# STATUS
---------- ----------------
 1 UNUSED
 2 CURRENT
 3 UNUSED

2.2:所有日志全丢了
恢复原理:找回日志文件的方式合上面完全相同。不同的是,开打数据库时需要验证一致性,这个时候加一个隐藏参数就可以了


SQL> select status,group# from v$log;

STATUS     GROUP#
---------------- ----------
INACTIVE        1
CURRENT       3
ACTIVE           2

SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo02.log'; 
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log'; 
ERROR at line 1:
ORA-01624: log 1 needed for crash recovery of instance orcl (thread 1)
ORA-00312: online log 1 thread 1: '/opt/oracle/oradata/orcl/redo01.log'
因为日志组1的状态是active。清空current,active日志组时需要介质恢复。


这个操作具体不知道是什么意思,但是可以使清空时不需要介质恢复              ???????????
SQL> recover database using backup controlfile;
回车
回车

再次清空日志组1,3就不会报错了
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log'; 
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo03.log'; 


打开数据库要求resetlogs打开
SQL> alter database open;
ORA-01589: must use RESETLOGS or NORESETLOGS option for database open

resetlogs需要介质恢复
SQL> alter database open resetlogs;
ORA-01113: file 1 needs media recovery
ORA-01110: data file 1: '/opt/oracle/oradata/orcl/system01.dbf'

设置隐藏参数不验证resetlogs
SQL> alter system set "_allow_resetlogs_corruption"=true scope=spfile;                ??????????????
System altered.

重启使参数生效
SQL> startup mount force;
ORACLE instance started.

Total System Global Area  209235968 bytes
Fixed Size    1335528 bytes
Variable Size  167776024 bytes
Database Buffers   37748736 bytes
Redo Buffers    2375680 bytes
Database mounted.

成功开启数据库
SQL> alter database open resetlogs;
Database altered.
 关闭隐藏参数
SQL> alter system reset "_allow_resetlogs_corruption" scope=spfile;
重启使隐藏参数失效
SQL>shutdown
SQL>startup




resetlogs 方法打开
SQL> startup mount;
SQL> alter system set "_allow_resetlogs_corruption"=true scope=spfile;
SQL> startup mount force;
SQL> recover database using backup controlfile;    是resetlogs方式打开数据库有效,resetlogs只有在recover database之后才能用
SQL> alter database open resetlogs;       会自动重建所有日志文件
SQL> alter system reset "_allow_resetlogs_corruption" scope=spfile;
SQL>shutdown
SQL>startup