网站首页 > 技术文章 正文
Oracle日志文件
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。
Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文件主要记录了数据库的操作过程,可以在进行数据库恢复时,将重做日志文件在还原的数据库上进行执行,以达到数据库的最新状态。
Oracle数据库在运行时,可以选择是否开启归档日志,在非归档日志的情况下,Oracle所有的操作日志都写在重做日志当中,当所有重做日志文件写满时(Oracle重做日志是分组的,默认是分为三组),那么就把前面的日志文件覆盖继续写入。而在开启归档日志模式情况下,当重做日志都写满时,继续要写入日志时,会把要覆盖的日志文件写入归档日志当中,然后再对重做日志进行覆盖,因此使用归档日志利于后期进行数据恢复。
那要怎么查看数据库是否开启归档日志?可以根据以下命令进行查询:
select t.NAME,t.LOG_MODE from v$database t;
代码解析:V$database数据字典主要存储数据库创建后的一些配置信息,其中LOG_MODE字段记录的就是是否开启归档日志文件,NOARCHIVELOG:表示未开启归档日志文件(Oracle在安装时默认选择的是不开启归档日志模式的)。
那重做日志文件的位置和属性信息如何查询,我们可以根据数据字典V$logfile进行查询,代码如下:
select *from v$logfile;
Oracle管理日志文件
Oracle数据库利用日志文件组对日志文件进行分组管理,Oracle数据库默认安装的是三个重做日志,三个日志文件组,每组一个日志文件,如下图:
其中status中current表示的是当前日志文件是正在使用(写入)的。
在实际使用当中,随着业务量的增大,操作数据库会变得频繁,日志文件读写切换太快,导致出现检查点等待问题,所以一般要增加或增大重做日志文件,或者直接一起增加日志文件组来解决性能问题。
因此,Oracle经常用到添加日志文件组、添加日志文件进文件组、删除日志文件、删除日志文件组四种方式对日志文件进行管理。具体命令步骤参考如下:
1、Oracle添加日志文件组
通过上面我们知道Oracle通过添加日志文件组达到扩充日志文件组的目的,然后再进行对其添加特定的日志文件,就达到扩充日志文件数的目的,解决了日志文件过少的性能问题。
Oracle增加日志文件组可以使用OEM企业管理器、SQL命令两种方式进行添加。这里我们采用SQL命令方式进行讲解,OEM企业管理器方式读者门可以自行试验。
创建日志文件组语法结构:
alter database add logfile group n filename size m
语法解析:
1、group n:表示创建日志文件组的组号,在Oracle当中日志文件组的组号是唯一的。
2、filename:表示日志文件组存储的位置。
3、size m:表示日志文件组的大小,默认是50M大小。
下面我们增加一个新的日志文件组4,大小100M,代码如下:
alter database add logfile group 4 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO04.LOG' size 100M;
执行完代码再看下日志文件组数量,如图:
2、Oracle添加日志文件进文件组
Oracle数据库中一个日志文件组可以包含多个日志文件,但是必须包含一个文件。因此,我们可以对建好的日志文件组进行扩充,语法结构如下:
alter database add logfile member filename to group n;
语法解析:
1、filename:表示日志文件存储的位置。
2、group n:表示添加到那个日志文件组。
利用上面的命令,我们对日志文件组4再添加一个日志文件,命令如下:
alter database add logfile member 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG' to group 4;
执行完代码,再查下一下日志文件,发现多了一个新添加的日志文件。
3、Oracle删除日志文件
我们不仅仅可以对日志文件组中进行添加日志文件,也可以把不必要的日志文件进行删除。
Oracle删除日志文件的语法结构如下:
alter database drop logfile member filename
语法解析:
1、filename:日志文件存储的位置。
2、当日志文件组只有一个日志文件时,是不能进行删除日志文件的,必须把整个日志文件组进行删除。
利用删除日志文件的命令,把刚刚添加的日志文件NEWREDO05进行删除,代码命令如下:
alter database drop logfile member 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG'
执行完代码,在查下日志文件,发现日志文件NEWREDO05已经删除了,如下图:
4、Oracle删除日志文件组
我们知道Oracle日志文件的重要性,我们不仅仅可以增加日志文件组,也可以对于过多的日志文件组进行整组删除。
Oracle删除日志文件组的语法结构:
alter database drop logfile group n
语法解析:
1、group n:表示要删除的文件组组号。
2、删除文件组,会对应的里面的日志文件一并全部删除。
利用删除日志文件组命令,把文件组4整组删除,代码如下:
alter database drop logfile group 4;
执行完代码,再查看下日志文件,发现日志文件组4,已经全部删除。如下图:
猜你喜欢
- 2024-10-15 oracle数据库的导入导出 oracle数据库数据导入
- 2024-10-15 oracle数据库delete删除操作可以恢复吗
- 2024-10-15 oracle数据库实例名变更流程 oracle数据库实例名修改
- 2024-10-15 工作必备!oracle常用命令总结 oracle19c常用命令
- 2024-10-15 Oracle管理日志文件 oracle系统日志在哪个文件夹
- 2024-10-15 Linux Oracle下sqlplus无法使用退格删除和历史记录解决小技巧
- 2024-10-15 当你不小心删了Oracle数据库控制文件时该怎么办?
- 2024-10-15 数据删除——ApachDoris 数据删除是什么意思
- 2024-10-15 「Oracle」 ORA-12705(字符集问题)
- 2024-10-15 windows环境下误删Oracle表空间文件解决方案
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)