Oracle-控制文件及日志文件的管理_oracle 把控制文件以文本形式进行备份,并查看相应的文本,

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注大数据)
img

正文

控制文件是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 sysdba
shutdown 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、重做日志文件组及成员的创建

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

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

logfile:包含重做日志文件成员信息。 v

logfile:包含重做日志文件成员信息。vlog_history:包含日志历史信息。

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

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

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)
[外链图片转存中…(img-4cJYskqp-1713316207019)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 23
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值