iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >详解Oracle控制文件及日志文件的管理问题
  • 681
分享到

详解Oracle控制文件及日志文件的管理问题

Oracle控制文件管理Oracle日志文件管理 2022-07-07 11:07:17 681人浏览 泡泡鱼
摘要

目录一、控制文件的管理1、控制文件的概述2、控制文件的创建1、控制文件的重新建立3、控制文件的备份1、将控制文件备份为二进制文件2、将控制文件备份为文本文件4、控制文件的恢复5、添加多路复用的控制文件二、重做日志文件的管

一、控制文件的管理

控制文件是oracle的物理文件之一,每个oracle数据库都必须至少有一个控制文件,它记录了数据库的名字、数据文件的位置等信息。在启动数据实例时,oracle会根据初始化参数定位控制文件,然后oracle会根据控制文件在实例和数据库之间建立关联。控制文件的重要性在于,一旦控制文件损坏,数据库将会无法启动。

1、控制文件的概述

控制文件在数据库创建时被自动创建,并在数据库发生物理变化时会同时更新。在任何时候都要保证控制文件是可用的。只有oracle进程才能够安全地更新控制文件的内容,所以,任何时候都不要试图手动编辑控制文件。

2、控制文件的创建

数据库在创建的时候,系统会根据初始化参数文件中control_files的设置创建控制文件。在后期数据库的使用过程中,如果控制文件丢失或者损坏,可以通过手工创建新的控制文件。
手工创建控制文件的基本语法如下所示。

create controlfile
reuse database db_name
logfile
group 1 redofiles_list1
...
datafile
...
maxlogfiles max_value1
maxlogmembers max_value2
maxinstances max_value3
maxdatafiles max_value4
noresetlogsiresetlogs
arcHiveloginoarchivelog;

参数说明如下。
db_name:数据库名称。
logfile:表示下面定义日志组文件。
redofiles_list1:重做日志组中的重做日志文件列表1名称及路径。
datafile:表示下面定义数据文件。
max_value1:最大的重做日志文件数。
max_value2:最大的重做日志组成员数。
max_value3:最大实例数。
max_value4:最大数据文件数。
新建控制文件的基本步骤如下。
1、查看数据库中所有的数据文件和重做日志文件的名称和路径。
2、关闭数据库。
3、备份所有的数据文件和重做日志文件。
4、启动数据库实例。
5、创建新的控制文件。
6、编辑初始化参数。
7、重新打开数据库。

1、控制文件的重新建立

1、查看数据库中所有的数据文件和重做日志文件的名称和路径。
如果数据库可以打开,则可以使用数据字典获取数据文件和日志文件的基本信息,如下所示。
使用数据字典v$logfile获取日志文件信息。

select member from v$logfile;

使用数据字典v$datafile获取数据文件信息。

select name from v$datafile;

使用数据字典v$controlfile获取控制文件信息。

select name from v$controlfile;

2、关闭数据库
如果数据库处于运行状态,在创建控制文件之前,首先以sys用户登录,关闭数据库。

conn sys/change_on_install as sysdbashutdown nORMal

3、备份所有的数据文件和重做日志文件。
4、启动数据库实例。
备份完成后,启动数据库,但是先不加载数据库,这主要是因为如果加载数据库,会同时打开控制文件,就无法实现创建新的控制文件的目的。

startup nomount

3、控制文件的备份

在日常数据库维护过程中,为了避免由于控制文件丢失或者损坏而导致数据库系统崩溃,需要经常对控制文件进行备份。特别是当修改了数据库结构之后,例如数据文件的添加、删除等,都需要及时重新备份控制文件。
备份控制文件可以使用下面语句来实现。

alter database backup controlfile

使用该语句一般有两种备份,一种是以二进制文件的形式进行备份,另一种是以文本文件的形式进行备份。下面就分别看一下如何实现控制文件的备份。

1、将控制文件备份为二进制文件

alter database backup controlfile to 'c:\bak.bkp';

上面代码实现将控制文件备份到C盘根目录下,文件名为bak.bkp,该文件以二进制形式存在。

2、将控制文件备份为文本文件

alter database backup controlfile to trace;

4、控制文件的恢复

当数据库由于各种情况发生损坏时,这时可以使用所备份的文件来恢复数据库。在日常维护中,经常会遇到两种情况,一种是控制文件损坏,另一种情况是磁盘发生故障。
当控制文件损坏时,这种情况较为简单,只需要用备份文件替换损坏的文件即可,不过复制之前要先关闭数据库,然后再复制,复制完成后需要重新启动。

5、添加多路复用的控制文件

为了提高数据库的可靠性,可以建立多个镜像的控制文件,并且分别保存在不同的磁盘中进行多路复用,这样就可以避免由于单个设备故障而使得数据库无法启动的情况发生,这种管理策略被称为多路复用控制文件。当某个磁盘发生物理损坏导致控制文件损坏,数据库将被关闭,此时就可以利用另一个磁盘中保存的控制文件来恢复被损坏的控制文件,然后再重新启动数据库,达到保护控制文件的目的。

二、重做日志文件的管理

重做日志文件也称为日志文件,是记录系统的日常操作、异常等行为的文件,是包含系统信息的文件,包括内核、服务、在系统上运行的应用程序等。重做日志文件是数据库安全和恢复的基本保障,当数据库出现故障的时候,管理员可以根据日志文件和数据库备份文件,将崩溃的数据库恢复到最近一次记录日志时的状态。

1、重做日志文件概述

在oracle数据库中,重做日志文件用于记录用户对数据库所做的各种变更操作所引起的数据变化,此时,所产生的操作会先写入重做日志缓冲区,当用户提交一个事务的时候,LGWR进程将与该事务相关的所有重做记录写入重做日志文件,同时生成一个“系统变更数”,scn会和重做记录一起保存到重做日志文件组,以标识与该事务提交成功。如果某个事务提交出现错误,可以通过重做记录找到数据库修改之前的内容,进行数据恢复。

2、查询重做日志文件信息

在oracl数据库日常运行过程中,数据库管理员可以查看重做日志文件信息,用于了解数据库的运行情况。这可以通过查询数据字典视图v l o g 、 v log、v log、vlogfile和v l o g h i s t o r y 来 实 现 , 通 过 它 们 可 以 查 询 的 信 息 如 下 。 v log_history来实现,通过它们可以查询的信息如下。 v logh​istory来实现,通过它们可以查询的信息如下。vlog:包含重做日志文件组的信息。
v l o g f i l e : 包 含 重 做 日 志 文 件 成 员 信 息 。 v logfile:包含重做日志文件成员信息。 v logfile:包含重做日志文件成员信息。vlog_history:包含日志历史信息。

3、重做日志文件组及成员的创建

在数据库的日常维护过程中,数据库管理员可以通过手工方式向数据库中添加新的重做日志组或日志文件,也可以改变重做日志文件的名称与位置,或者删除重做日志组或其成员。

1、创建重做日志文件组
语法如下:

alter database add logfile [group] [编号](日志文件) size

上面语句中group可选,当不选择的时候,系统会自动产生组号,为当前重做日志文件组的个数加1。

4、重做日志文件组及成员的删除

当重做日志文件组,其成员不合适或者所在存储位置出现错误时,此时可以将重做日志文件组或者其成员删除。

1、删除重做日志成员文件
删除重做日志文件成员使用如下语法。

alter database drop logfile member 文件名

删除group5添加的新成员文件

alter database drop logfile member 'd:\app\redo05_3.log';

5、修改重做日志文件的名称或位置

在数据库正常使用中,如果想要改变重做日志文件的名称或位置,可以按照如下步骤进行重做日志文件的修改。
1、关闭数据库。
2、复制或者修改日志文件的位置。
3、启动数据库实例,但不打开数据库,只加载数据库。
4、重新设置重做日志文件的名称或位置。
5、打开数据库。

三、归档日志文件的管理

在oracle数据库中,重做日志文件用于记录用户对数据库所做的各种变更操作所引起的数据变化。在把这些变化写入重做的日志文件的时候,一般情况下有多个重做日志文件组,每个文件组有多个文件,oracle向这些重做文件写入的时候,一般情况下有多个重做日志文件组,每个文件组有多个文件,oracle向这些重做文件写入的时候,是使用循环的方式向这些重做日志文件组中的文件进行写入的,当最后一个重做日志文件组中的文件内容写满后,会重新写入第一个重做日志文件组中的文件。在这种情况下,原先重做日志文件的内容如何处理,是直接覆盖还是把原先的记录保存,就是我们要介绍的归档日志。

1、归档日志文件概述

所谓归档日志文件就是指当重做日志文件写满的时候,把其中内容保存到新的文件中,这些新的文件集合就是归档日志文件。但是重做日志文件并不一定主动被保存到新的文件中,根据数据库设置不同,oracle有两种日志模式:归档日志模式和非归档日志模式。在非归档日志模式下,原日志文件的内容会被新的日志内容所覆盖;在归档日志模式下,oracle会首先对原日志文件进行归档存储,且在归档未完成之前不允许覆盖原有日志。

2、归档日志信息的查询

数据库管理人员可以修改归档日志文件和非归档日志文件,但首先需要了解归档日志信息。在oracle中,可以通过查询数据字典了解归档日志的一些基本信息,常用的数据字典有v a r c h i v e d l o g 、 v archived_log、v archivedl​og、varchive_dest、v$database等

3、归档模式的设置

默认情况下,oracle数据库处于非归档日志模式,即当重做日志文件写满的时候,直接覆盖里面的内容,原先的日志记录不会被写入到归档日志文件中。根据oracle数据库对应的应用系统不同,数据库管理员可以把数据库的日志模式在归档模式和非归档模式之间进行切换。可以通过alter database archivelog或noarchivelog语句实现数据库在归档模式与非归档模式之间进行切换。
切换步骤如下:
1、关闭数据库

shutdown immediate;

2、将数据库启动到加载状态。

startup mount;

3、修改数据库的归档模式或非归档模式
归档模式修改为非归档模式

alter database noarchivelog;

非归档模式修改为归档模式

alter database archivelog;

4、重新打开数据库

alter database open;

四、总结

这里的相关内容还没有整理完毕,文章后面持续更新,建议收藏。

文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。

到此这篇关于Oracle控制文件及日志文件的管理的文章就介绍到这了,更多相关Oracle控制文件管理内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: 详解Oracle控制文件及日志文件的管理问题

本文链接: https://www.lsjlt.com/news/33248.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go语言中如何处理并发文件的文件系统文件日志和审计日志问题?
    Go语言中如何处理并发文件的文件系统文件日志和审计日志问题?在Go语言中,处理并发文件的文件系统文件日志和审计日志问题是一项常见的需求。Go语言提供了多种机制来处理并发文件操作,如锁机制、管道、协程等。本文将介绍如何在Go语言中处理文件系统...
    99+
    2023-10-22
    并发处理 文件系统 审计日志
  • win10日志文件c:Windowssystem32logfiles问题怎么解决
    今天小编给大家分享一下win10日志文件c:Windowssystem32logfiles问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下...
    99+
    2023-07-01
  • oracle的控制文件深入理解(一)
    Oracle的control文件 这里我们要实验的是数据库在open的状态下,破快控制文件,数据库会不会down   查看controlfiles的路径 SQL>...
    99+
    2024-04-02
  • SpringBoot详细讲解日志文件
    目录1 日志的功能是什么2 如何自定义日志打印2.1 在程序中获取日志对象2.2 调用日志对象打印日志2.3 查看日志打印的结果3 日志的级别3.1 日志级别的分类3.2 日志级别的...
    99+
    2024-04-02
  • logback日志文件路径问题如何解决
    这篇文章给大家介绍logback日志文件路径问题如何解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。对于J2SE项目,当前路径为工程所在目录如我的工程为:D:\test则使用…/logs生成的日志文件位于:D:\lo...
    99+
    2023-06-06
  • Oracle联机日志文件与归档文件详细介绍
    管理联机日志文件: 联机日志文件以组为单位工作 数据库正常工作至少需要2组日志 联机日志记录所有数据块的变化,用来做实例recover 同一组下的成员之间是镜像关系 more情况日志成员写满redo时发生切换 日志切换时...
    99+
    2022-11-22
    Oracle联机日志文件 Oracle归档文件
  • Python编解码问题及文本文件处理方法详解
    编解码器 在字符与字节之间的转换过程称为编解码,Python自带了超过100种编解码器,比如: ascii(英文体系) gb2312(中文体系) utf-...
    99+
    2024-04-02
  • logrotate中怎么管理VPS日志文件
    这篇文章将为大家详细讲解有关logrotate中怎么管理VPS日志文件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。logrotate 程序还可以用于压缩日志文件,以及发送日志到指定的E-m...
    99+
    2023-06-10
  • 如何解决Oracle RMAN 备份控制文件报错问题
    本篇文章为大家展示了如何解决Oracle RMAN 备份控制文件报错问题,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。从11gR2开始,控制文件备份在不保留控制文件...
    99+
    2024-04-02
  • log4j如何控制日志输出文件名称
    小编给大家分享一下log4j如何控制日志输出文件名称,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!log4j控制日志输出文件名称1. 第一种方式在类对象中用如下方...
    99+
    2023-06-22
  • Linux下如何解决日志文件过大的问题
    这篇文章主要介绍Linux下如何解决日志文件过大的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!如何让应用程序在后台执行:linux后台执行命令:&与nohup的用法通过以上方法,应用程序的日志会一直输出...
    99+
    2023-06-15
  • 关于logBack配置日志文件及编码配置的问题
    记录下使用logback中遇到的问题,方便以后查看 logback输出到文件文件大小设置问题 目前网上能搜到的关于输出到日志文件的大小设置有如下两种: 1.单独的triggering...
    99+
    2024-04-02
  • 使用Oracle跟踪文件的问题详解
    一、什么是跟踪文件? 跟踪文件中包含了大量而详细的诊断和调试信息。通过对跟踪文件的解读和分析,我们可以定位问题、分析问题和解决问题。从跟踪文件的产生的来源来看,跟踪文件又可以分为两类...
    99+
    2024-04-02
  • SQLServer清理日志文件方法案例详解
    很多时候SQLSERVER的日志文件是不看的,但时间久了,够把磁盘撑爆,这时候就需要清理日志文件。使用以下方法,在实际环境中经过测试,400G的日志文件1秒就被清理。 操作步骤 1....
    99+
    2024-04-02
  • PHP日志打包API:如何优化日志文件的管理?
    在Web开发过程中,日志记录是必不可少的一部分。每个应用程序都需要记录各种信息,从简单的调试信息到错误报告。但是,管理这些日志文件可能会变得非常困难,尤其是在应用程序变得越来越复杂的情况下。为了应对这种情况,我们可以使用PHP日志打包AP...
    99+
    2023-10-03
    日志 打包 api
  • oracle日志文件满了怎么清理
    Oracle数据库的日志文件主要包括归档日志文件和在线重做日志文件。当日志文件满了之后,需要及时清理以释放空间。以下是清理Oracl...
    99+
    2024-04-09
    oracle
  • 如何解决Laravel日志文件写入失败问题
    这篇文章将为大家详细讲解有关如何解决Laravel日志文件写入失败问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在讲这个问题之前可能需要简单介绍下Linux系统下的文件的Ownership和Permi...
    99+
    2023-06-04
  • 【翻译】控制文件管理(Managing Control Files)
    原文所在的链接为:http://docs.oracle.com/cd/E11882_01/server.112/e25494/control.htm#ADMIN006 1. 控制文件管理 ...
    99+
    2024-04-02
  • log4j2.xml文件详解及在日志中加入全局guid
    目录log4j2.xml文件及在日志中加入全局guid只有定义了这个,上面的才会真实有效想在日志中加入全局guid需要修改日志的格式log4j2.x配置文件中各标签1、Logger ...
    99+
    2024-04-02
  • SpringBoot项目创建使用+配置文件+日志文件详解
    目录1. Spring Boot 项目创建2. 写一个 Hello World 并运行3. 配置文件的作用及格式4. properties 配置文件的基本语法 5. 读取配...
    99+
    2023-02-09
    SpringBoot项目创建使用 SpringBoot配置文件 SpringBoot日志文件
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作