- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章DBF 文件恢复 ORACLE 数据库的方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
清·魏源《庸易通义》:“至道问学之有知无行,分温故为存心,知新为致知,而敦厚为存心,崇礼为致知,此皆百密一疏。” 。
。
起因 。
在我们的生产活动中,意外总是在不经意间发生。那天一个安装有 oracle 数据库的盘符不小心被格式化了,好几个项目都炸了。不过还好有备份,不过只有 .DBF 文件和几个日志文件:
1
2
3
4
5
6
7
8
9
10
11
12
|
//数据库系统相关
REDO01.LOG
REDO02.LOG
REDO03.LOG
SYSTEM01.DBF
UNDOTBS01.DBF
SYSAUX01.DBF
USERS01.DBF
//项目相关
xxx.DBF
|
。
解决 。
。
前期准备 。
重新安装和之前一样的数据库版本、实例名都和之前的一致;编写创建控制文件 CONTROLFILE 的命令.
控制文件(Control File)是Oracle的物理文件之一,它记录了数据库的名字、数据文件的位置等信息。控制文件的重要性在于,一旦控制文件损坏,数据库将会宕机。如果没有数据库的备份和归档日志文件,数据库将无法恢复。因此,我们应该多路镜像控制文件(Multiplex Control Files),并把每个镜像的控制文件分布在不同的物理磁盘。根据经验,控制文件多路镜像以后,几个控制文件同时坏掉的可能性几乎为零。控制文件管理的重心是重在预防,而不是亡羊补牢! 。
控制文件实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
CREATE
CONTROLFILE REUSE
DATABASE
"数据库名(orcl)"
NORESETLOGS ARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 454
LOGFILE
GROUP
1
'需要恢复的日志文件路径(E:\oradata\orcl\)REDO01.LOG'
SIZE
50M,
GROUP
2
'同上\REDO02.LOG'
SIZE
50M,
GROUP
3
'同上\REDO03.LOG'
SIZE
50M
DATAFILE(数据文件)
-- 系统相关
'需要恢复的数据文件路径(E:\oradata\orcl\)SYSTEM01.DBF'
,
'需要恢复的数据文件路径(E:\oradata\orcl\)UNDOTBS01.DBF'
,
'需要恢复的数据文件路径(E:\oradata\orcl\)SYSAUX01.DBF'
,
'需要恢复的数据文件路径(E:\oradata\orcl\)USERS01.DBF'
,
-- 用户数据相关
'需要恢复的数据文件路径(E:\oradata\orcl\)TEST01.DBF'
,
'需要恢复的数据文件路径(E:\oradata\orcl\)TEST02.DBF'
'
CHARACTER
SET
ZHS16GBK;
|
。
操作步骤 。
1.进入 cmd 输入命令:
1
|
sqlplus
|
然后以数据库管理员身份登录系统,输入:
1
|
sys / as sysdba
|
输入命令回车,下一步输入密码即可进入到数据库命令行模式。 2.备份控制文件到 trace 文件,输入命令:
1
|
alter
database
backup controlfile
to
trace;
|
3.停止数据库,输入命令:
1
|
shutdown immediate;
|
4.以 nomount 状态启动数据库,输入命令:
1
|
startup nomount;
|
5.执行创建控制文件的命令,输入前期准备好的创建控制文件的命令: 6.恢复数据库,输入命令:
1
|
recover database;
|
7.将数据库从 mount 状态切换到 open 状态,这时就是使用数据库了,输入命令:
1
|
alter database open;
|
oracle数据库启动分三个步骤 nomount mount open startup是数据库从开始阶段的启动du,需要经过上述zhi三个步dao骤 alter database open是数据库处于mount状态,从mount状态打开数据库的命令 。
至此,dbf 文件恢复 oracle 数据库就完成了。祝君好运! 。
。
期间遇到的问题 。
有问题不要害怕,一个一个去解决它,从中汲取养料,相信自己.
。
问题一 。
数据库恢复成功后,连接数据库遇到 。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aNrFPOfC-1609941209785)(https://cdn.jsdelivr.net/gh/filess/img10@main/2021/01/06/1609939139070-3baeea76-c41a-48f7-b36b-fb1c3f3f6ce0.png)] 。
因为归档文件的空间满了。 解决一 增加归档日志空间或者删除归档日志(谨慎操作),可同时操作。 1.增加归档日志空间:
1
2
3
4
|
//查看当前归档空间大小
select
*
from
v$recovery_file_dest;
//相应增加归档日志空间大小
alter
system
set
db_recovery_file_dest_size=20G scope=both;
|
2.删除归档日志 。
1
2
3
4
|
//重新打开一个 cmd 窗口,输入命令:进入 rman
rman target /
//删除所有的归档日志
delete
archivelog
all
;
|
。
问题二 。
ORA-00379: no free buffers available in buffer pool DEFAULT for block size 16K 缓冲池 DEFAULT 中无法提供 16K 块大小的空闲缓冲区 。
解决二 。
查看 16K 块大小 。
1
|
show parameter db_16k_cache_size
|
2.设置 16K 块缓冲区大小 。
1
|
alter
system
set
db_16k_cache_size=10m;
|
。
问题三 。
ORA-12516 ORA-12516: TNS: 监听程序找不到符合协议堆栈要求的可用处理程' 。
解决三 。
1.查看数据库现有的进程(process)数是否已经达到参数 processes 的大小;当前会话数量(session)是否达到参数 sessions 的大小.
1
2
3
4
5
6
7
8
|
//获取当前数据库所有的进程数量
select
count
(*)
from
v$process;
//获取当前数据库所有会话数量
select
count
(*)
from
v$session;
//获取 processes 大小
show parameter processes;
//获取 sessions 大小
show parameter sessions
|
2.修改 processes 值和 sessions 值 。
1
2
|
alter
system
set
processes=300 scope=spfile;
alter
system
set
sessions=335 scope=spfile;
|
3.重启数据库生效 。
1
2
|
shutdown immediate; or shutdown
startup
|
到此这篇关于DBF 文件 ORACLE 数据库恢复的文章就介绍到这了,更多相关DBF 文件 ORACLE 数据库恢复内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/angell-N/p/14243675.html 。
最后此篇关于DBF 文件恢复 ORACLE 数据库的方法的文章就讲到这里了,如果你想了解更多关于DBF 文件恢复 ORACLE 数据库的方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我想了解 Ruby 方法 methods() 是如何工作的。 我尝试使用“ruby 方法”在 Google 上搜索,但这不是我需要的。 我也看过 ruby-doc.org,但我没有找到这种方法。
Test 方法 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。 object.Test(string) 参数 object 必选项。总是一个
Replace 方法 替换在正则表达式查找中找到的文本。 object.Replace(string1, string2) 参数 object 必选项。总是一个 RegExp 对象的名称。
Raise 方法 生成运行时错误 object.Raise(number, source, description, helpfile, helpcontext) 参数 object 应为
Execute 方法 对指定的字符串执行正则表达式搜索。 object.Execute(string) 参数 object 必选项。总是一个 RegExp 对象的名称。 string
Clear 方法 清除 Err 对象的所有属性设置。 object.Clear object 应为 Err 对象的名称。 说明 在错误处理后,使用 Clear 显式地清除 Err 对象。此
CopyFile 方法 将一个或多个文件从某位置复制到另一位置。 object.CopyFile source, destination[, overwrite] 参数 object 必选
Copy 方法 将指定的文件或文件夹从某位置复制到另一位置。 object.Copy destination[, overwrite] 参数 object 必选项。应为 File 或 F
Close 方法 关闭打开的 TextStream 文件。 object.Close object 应为 TextStream 对象的名称。 说明 下面例子举例说明如何使用 Close 方
BuildPath 方法 向现有路径后添加名称。 object.BuildPath(path, name) 参数 object 必选项。应为 FileSystemObject 对象的名称
GetFolder 方法 返回与指定的路径中某文件夹相应的 Folder 对象。 object.GetFolder(folderspec) 参数 object 必选项。应为 FileSy
GetFileName 方法 返回指定路径(不是指定驱动器路径部分)的最后一个文件或文件夹。 object.GetFileName(pathspec) 参数 object 必选项。应为
GetFile 方法 返回与指定路径中某文件相应的 File 对象。 object.GetFile(filespec) 参数 object 必选项。应为 FileSystemObject
GetExtensionName 方法 返回字符串,该字符串包含路径最后一个组成部分的扩展名。 object.GetExtensionName(path) 参数 object 必选项。应
GetDriveName 方法 返回包含指定路径中驱动器名的字符串。 object.GetDriveName(path) 参数 object 必选项。应为 FileSystemObjec
GetDrive 方法 返回与指定的路径中驱动器相对应的 Drive 对象。 object.GetDrive drivespec 参数 object 必选项。应为 FileSystemO
GetBaseName 方法 返回字符串,其中包含文件的基本名 (不带扩展名), 或者提供的路径说明中的文件夹。 object.GetBaseName(path) 参数 object 必
GetAbsolutePathName 方法 从提供的指定路径中返回完整且含义明确的路径。 object.GetAbsolutePathName(pathspec) 参数 object
FolderExists 方法 如果指定的文件夹存在,则返回 True;否则返回 False。 object.FolderExists(folderspec) 参数 object 必选项
FileExists 方法 如果指定的文件存在返回 True;否则返回 False。 object.FileExists(filespec) 参数 object 必选项。应为 FileS
我是一名优秀的程序员,十分优秀!