重建redo文件
需求背景
由于前期安装oracle时redo文件大小或者路径规划不合理需要进行修改,以便满足性能测试要求。redo文件规划大小建议与生产环境一致。
重做日志相关数据字典
1、v$log 记录数据库中有多少个重做日志组,每个组中有多少个成员、日志大小及状态
2、v$logfile 记录着每个日志组成员的属性、文件路径、文件名、状态等
操作步骤
1、查看现有日志组及重做文件大小
SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log;
GROUP# SEQUENCE# SIZEMB MEMBERS STATUS
---------- ---------- ---------- ---------- ---------
1 27 50 1 INACTIVE
2 28 50 1 CURRENT
3 29 50 1 INACTIVE
STAUS状态值说明:
inactive:表示实例恢复已不再需要这组联机重做日志组了。
active:表示该组是活动的但不是当前组,实例恢复时需要这组日志。
current:表示该组日志是当前组,该联机重做日志组是活动的,当前正在使用。
unused:表示该日志组从未写过,是重做日志刚刚添加到状态。
2、查看当前重做日志文件的状态和路径
SQL> select group#,status,type,member from v$logfile;
GROUP# STATUS TYPE MEMBER
---------- ------- ------- ---------------------------------------------
3 ONLINE /home/oracle/oradata/ora11g/redo03.log
2 ONLINE /home/oracle/oradata/ora11g/redo02.log
1 ONLINE /home/oracle/oradata/ora11g/redo01.log
STATUS状态说明:
空白:表示该文件正在使用。
stale:表示该文件中的内容是不完全的。
invalid:表示该文件是不可以被访问的。
deleted:表示该文件已不再有用了。
3、新增创建重做日志文件组group 4、group 5、group 6,文件大小设置为1000M。
SQL> alter database add logfile group 4('/dev/vgoracle/lvredo4.log') size 1000M; Database altered. SQL> alter database add logfile group 5('/dev/vgoracle/lvredo5.log') size 1000M; Database altered. SQL> alter database add logfile group 6('/dev/vgoracle/lvredo6.log') size 1000M; Database altered.
4、执行alert system switch logfile命令进行多次切换,直至group 4或者group 5日志组的状态为current。
SQL> alter system switch logfile; System altered. SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log; GROUP# SEQUENCE# SIZEMB MEMBERS STATUS ---------- ---------- ---------- ---------- --------- 1 27 50 1 INACTIVE 2 28 50 1 ACTIVE 3 29 50 1 INACTIVE 4 30 50 1 CURRENT 5 31 50 1 NOUSE 6 32 50 1 NOUSE
5、执行alter system checkpoint手工执行同步数据,将redo文件记录写入数据文件。确保group 1、group 2、group 3文件组状态为INACTIVE。
SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log; GROUP# SEQUENCE# SIZEMB MEMBERS STATUS ---------- ---------- ---------- ---------- --------- 1 27 50 1 INACTIVE 2 28 50 1 INACTIVE 3 29 50 1 INACTIVE 4 30 50 1 CURRENT 5 31 50 1 NOUSE 6 32 50 1 NOUSE
6、当日志组处于INACTIVE状态是,可以执行drop操作删除。对应的OS文件需手工删除。
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.
7、操作完成。重新查看重做日志文件组状态
SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log; GROUP# SEQUENCE# SIZEMB MEMBERS STATUS ---------- ---------- ---------- ---------- --------- 4 30 1000 1 ACTIVE 5 31 1000 1 NOUSE 6 32 1000 1 NOUSE
说明:如果习惯使用日志组1/2/3,可以按照上述过程重新操作一遍即可。
8、清理被替换的redo文件
rm /home/oracle/oradata/ora11g/redo01.log rm /home/oracle/oradata/ora11g/redo02.log rm /home/oracle/oradata/ora11g/redo03.log
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义