设为首页 收藏本站
查看: 1461|回复: 0

[经验分享] oracle日志文件的整理

[复制链接]

尚未签到

发表于 2018-9-25 08:24:40 | 显示全部楼层 |阅读模式
  在上大学期间王强老师的课程中的整理以及修改,对日志文件的管理讲解很详细,
  一、增加日志组
  实例1:为oracle数据库增加一个重做日志组,组号自动分配,组中包含两个日志成员,大小为10M,并查询动态性能视图确定能否成功。操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  或
  sqlplusw  sys/wangwang as sysdba
  2. 增加日志组:

  >  或

  alter database dog  add logfile ('d:\log\log4a.log','d:\log\log4b.log')>  3. 查询日志信息(包括组号,成员数,成员,每个成员的大小):
  SQL> col member format a50
  SQL> select a.group#,a.members,a.bytes,b.member from v$log a, v$logfile b where a.group#=b.group#;
  GROUP#    MEMBERS      BYTES                          MEMBER
  ------- ---------- ---------- ------------------------  ----------------------------------------------------------------------------------
  3          1       10485760       D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO03.LOG
  2          1       10485760       D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO02.LOG
  1          1       10485760       D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO01.LOG
  或
  SQL> select group#,member from v$logfile;
  GROUP#           MEMBER
  ------      -------------------------------------------------------------------------------------
  3    D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO03.LOG
  2    D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO02.LOG
  1    D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO01.LOG
  或
  SQL> select group#,members,bytes from v$log;
  GROUP#    MEMBERS      BYTES
  --------------------  ---------- ---------- ---------- ----------
  1          1          10485760
  2          1          10485760
  3          1          10485760
  

  实例2:为oracle数据库再增加一个重做日志组,指定组号,组中包含两个日志成员,大小为10M,并查询动态性能视图确定能否成功操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 增加日志组:

  SQL>>  或

  SQL>>  3. 查询日志信息:
  SQL> col member format a50
  SQL> select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group# order by a.group#;
  或
  SQL> select group#,member from v$logfile;
  或
  SQL> select group#,members,bytes from v$log;
  二、增加日志成员
  实例3:为oracle服务器的第4个重做日志组增加一个日志成员"log4c.lg".
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 增加日志成员:

  SQL>>  或

  SQL>>  3. 查询日志信息:
  SQL> col member format a50
  SQL> select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group#;
  或SQL> select group#,member from v$logfile;(显示用户数据库日志组和成员)
  或SQL> select group#,members,bytes from v$log;
  练习:为每个日志组添加一个日志成员。
  

  三、删除日志组(注意:current/active状态下或只有两个日志组都不能删除该日志组)
  实例4:删除日志组4
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 查看日志组的状态(只有INACTIVE和UNUSED状态的可删除)
  SQL> select group#,status,members,bytes  from v$log;
  3. 删除日志组4(下面的命令只是逻辑删除,要物理删除得用os命令)

  SQL>>  或

  SQL>>  此时不能再往日志组4中添加成员,如:

  >  出现错误信息:
  第 1 行出现错误:
  ORA-00359: 日志文件组 4 不存在
  如果2号日志组是当前日志组,执行删除2号日志组的操作,则会出现错误。

  SQL>>  错误提示信息如下:
  alter database dog drop logfile group 2
  *
  第 1 行出现错误:
  ORA-01623: 日志 2 是实例 dog (线程 1) 的当前日志 - 无法删除
  ORA-00312: 联机日志 2 线程 1: 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\DOG\REDO02.LOG'
  4. 查询日志信息:
  SQL> col member format a50
  SQL> select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group#;
  或SQL> select group#,member from v$logfile;
  或SQL> select group#,members,bytes from v$log;
  

  四、删除日志成员(注意:current状态下或日志组中只有一个日志成员时不能删除)
  实例5:删除日志组5中的第2个日志组成员
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 查看日志组的状态
  SQL> select group#,status,members,bytes  from v$log;
  3. 删除日志组4中的第2、3个日志组成员

  SQL>>  4. 查询日志信息:
  SQL> col member format a50
  SQL> select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group#;
  或SQL> select group#,member from v$logfile;
  或SQL> select group#,members,bytes,status from v$log;
  注意:日志组中只有一个日志成员时不能删除,如:

  SQL>>  此时,出现如下信息:
  第 1 行出现错误:
  ORA-00361: 无法删除最后一个日志成员 d:\log\log4a.log (组 4)
  

  五、清空重做日志
  实例6:清空重做日志组4
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 关闭数据库
  SQL> shutdown immediate
  删除4号日志组的所有成员,再启动则出现错误:
  3. 启动数据库
  SQL> startup
  ORACLE 例程已经启动。
  错误提示信息如下:
  Total System Global Area  285212672 bytes

  Fixed>
  Variable>  Database Buffers          205520896 bytes
  Redo Buffers                7139328 bytes
  数据库装载完毕。
  ORA-00313: 无法打开日志组 4 (用于线程 1) 的成员
  ORA-00312: 联机日志 4 线程 1: 'D:\LOG\LOG4A.LOG'
  ORA-00312: 联机日志 4 线程 1: 'D:\LOG\LOG4C.LOG'
  ORA-00312: 联机日志 4 线程 1: 'D:\LOG\LOG4B.LOG'
  查看数据库的启动状态:
  SQL> select status from v$instance;
  或直接启动数据库到加载状态(特别注意)
  SQL> startup  mount
  4. 清空重做日志组4,恢复该日志组的成员

  SQL>>  5. 查询日志信息:
  SQL> col member format a50
  SQL> select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group#;
  或
  SQL> select a.group#,a.status,a.members from v$log a,v$logfile b where a.group#=b.group#;
  6.改变日志的模式

  SQL>>  六、移动日志文件
  实例7:移动日志文件,观察日志文件丢失时的现象,并重新定位。
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 关闭数据库
  shutdown
  3. 物理移动日志成员到目标位置
  将文件d:\oracle\product\10.2.0\oradata\jlfx\REDO03.log 移动到 d:\REDO03.log;
  4. 打开数据库
  startup;
  5. 执行rename命令,重新定位日志文件

  >  或
  alter  database  dog  rename  file 'd:\log\log4b.log' to 'd:\log4b.log';
  6. 打开数据库

  >  7. 查询日志信息:
  col member format a50
  select a.group#,a.status,a.members,a.bytes,b.member from v$log a,v$logfile b where a.group#=b.group#;
  七、手工日志切换
  实例8:强制切换日志,显示日志状态
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 查看日志组的状态
  select group#,sequence#,members,status from v$log;
  3. 手工日志切换(在open状态下操作)

  >  4. 查看日志组及成员的状态
  select group#,sequence#,members,status from v$log;
  八、日志归档(归档模式:archivelog,非归档模式:noarchivelog)
  注意:数据库只有在加载状态下才能修改日志模式
  实例9:查看数据库的日志操作模式,然后将数据库修改为归档模式
  操作步骤如下:
  1. 以系统管理员身份登入:
  sqlplusw   sys/jlfx  as  sysdba
  2. 关闭数据库,然后加载数据库
  shutdown immediate
  startup mount
  3. 查看归档模式
  archive log list;
  或 select  name,log_mode  from  v$database;
  4. 修改归档模式

  >
  >

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-600949-1-1.html 上篇帖子: 空间占满,oracle起不来 下篇帖子: Oracle生成随机码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表