ORACLE模拟临时文件、日志成员、口令文件丢失情况与恢复【weber出品】
一、临时表空间文件、日志文件和口令文件都属于非关键性文件,因为这些文件丢失后并不会影响到整个数据库的完整性。
但是,当这些文件丢失后我们需要快速的找回这些文件。接下来我将模拟临时表空间文件、日志文件和口令文件丢失的情况。
二、如果属于 TEMP 表空间的临时文件丢失或损坏,则 TEMP 表空间将不可用。例如:在执行需要 TEMP 空间进行排序的 SQL 语句过程中,此问题将声明其为错误。
一般会用到临时表空间的场景有:
索引create或rebuild
select NAME from v$tempfile; NAME
--------------------------------------------------------------------------------
/u01/oracle/oradata/orcl/temp02.dbf SQL> show parameter pga NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
pga_aggregate_target big integer 192M
SQL> alter system set pga_aggregate_target=10M;
把pga_aggregate_target给调小些,这样order by的时候就一定会用到临时文件了。
rm -rf /u01/oracle/oradata/orcl/temp02.dbf
创建模拟表
SQL> conn scott/tiger SQL> create table temp_table as select * from all_objects; SQL> insert into temp_table select * from all_objects; SQL> commit; SQL> SQL> select * from temp_table order by ,,,,,,,,,,,,;
select * from temp_table order by ,,,,,,,,,,,,
*
ERROR at line :
ORA-: error in opening database file
ORA-: data file : '/u01/oracle/oradata/orcl/temp01.dbf'
ORA-: unable to open file
Linux Error: : No such file or directory
Additional information:
不需要重新启动数据库就可以恢复丢失的 TEMPFILE。
如果要恢复数据库,可以先在数据库中添加一个新的数据文件,然后删除那个已在 OS 层删除的数据文件。
SQL> conn / as sysdba
Connected.
SQL> ALTER TABLESPACE temp ADD TEMPFILE '/u01/oracle/oradata/orcl/temp02.dbf' SIZE 20M;
Tablespace altered.
SQL> ALTER TABLESPACE temp DROP TEMPFILE '/u01/oracle/oradata/orcl/temp01.dbf';
Tablespace altered.
SQL> select name from v$tempfile; NAME
--------------------------------------------------------------------------------
/u01/oracle/oradata/orcl/temp02.dbf
再次执行order by的语句就可以成功了。因为临时文件的内容不是非常的重要,属于可有可无的那种,没有了重建就是了。
select a.group#,a.sequence#,a.archived,a.status,b.member from v$log a,v$logfile b
where a.group#=b.group#
order by ; GROUP# SEQUENCE# ARC STATUS MEMBER
------ --------- --- -------- ------------------------------------------
YES CURRENT /u01/oracle/oradata/orcl/redo01.log
YES CURRENT /u01/oracle/oradata/orcl/redo0101.log
NO INACTIVE /u01/oracle/oradata/orcl/redo0201.log
NO INACTIVE /u01/oracle/oradata/orcl/redo02.log
YES INACTIVE /u01/oracle/oradata/orcl/redo0301.log
YES INACTIVE /u01/oracle/oradata/orcl/redo03.log SQL> !rm -rf /u01/oracle/oradata/orcl/redo01.log SQL> !rm -rf /u01/oracle/oradata/orcl/redo0101.log
接下来将current转换成active状态:
SQL> alter system switch logfile;--先让其变成ACTIVE System altered. SQL> select a.group#,a.sequence#,a.archived,a.status,b.member from v$log a,v$logfile b
where a.group#=b.group#
order by ; GROUP# SEQUENCE# ARC STATUS MEMBER
------ --------- --- -------- ------------------------------------------
NO ACTIVE /u01/oracle/oradata/orcl/redo01.log
NO ACTIVE /u01/oracle/oradata/orcl/redo0101.log
NO CURRENT /u01/oracle/oradata/orcl/redo0201.log
NO CURRENT /u01/oracle/oradata/orcl/redo02.log
YES INACTIVE /u01/oracle/oradata/orcl/redo0301.log
YES INACTIVE /u01/oracle/oradata/orcl/redo03.log rows selected. SQL> alter system checkpoint;--再让其变成INACTIVE System altered. SQL> select a.group#,a.sequence#,a.archived,a.status,b.member from v$log a,v$logfile b
where a.group#=b.group#
order by ; GROUP# SEQUENCE# ARC STATUS MEMBER
------ --------- --- -------- ------------------------------------------
NO INACTIVE /u01/oracle/oradata/orcl/redo01.log
NO INACTIVE /u01/oracle/oradata/orcl/redo0101.log
NO CURRENT /u01/oracle/oradata/orcl/redo0201.log
NO CURRENT /u01/oracle/oradata/orcl/redo02.log
YES INACTIVE /u01/oracle/oradata/orcl/redo0301.log
YES INACTIVE /u01/oracle/oradata/orcl/redo03.log rows selected.
关闭数据库,启动到mounted状态下:
SQL> shutdown immediate
SQL>startup mount SQL>alter database clear unarchived logfile group 1---清除
SQL> alter database open;
Database altered.
SQL> select a.group#,a.sequence#,a.archived,a.status,b.member from v$log a,v$logfile b
where a.group#=b.group#
order by 1; 2 3
GROUP# SEQUENCE# ARC STATUS MEMBER
------ --------- --- -------- ------------------------------------------
1 24 NO CURRENT /u01/oracle/oradata/orcl/redo01.log
1 24 NO CURRENT /u01/oracle/oradata/orcl/redo0101.log
2 23 YES INACTIVE /u01/oracle/oradata/orcl/redo0201.log
2 23 YES INACTIVE /u01/oracle/oradata/orcl/redo02.log
3 21 YES INACTIVE /u01/oracle/oradata/orcl/redo0301.log
3 21 YES INACTIVE /u01/oracle/oradata/orcl/redo03.log
好了,这样重做日志组1就回来了。不过,current日志组的成员如果一旦两个都坏了,虽然整个数据还是完整的,但是如果想要恢复current这个业务之前的状态就有不可以了。
删除口令文件:
cd $ORACLE_HOME/dbs/
rm -rf orapworcl
使用操作系统验证登陆数据库:
[oracle@nylg dbs]$ sqlplus sys/a@orcl as sysdba SQL*Plus: Release 10.2.0.1. - Production on Sat Aug :: Copyright (c) , , Oracle. All rights reserved. ERROR:
ORA-: insufficient privileges Enter user-name:
口令文件丢失,使用口令验证无法登陆,只能通过操作系统验证登陆
[oracle@nylg dbs]$ sqlplus / as sysdba SQL*Plus: Release 10.2.0.1. - Production on Sat Aug :: Copyright (c) , , Oracle. All rights reserved. Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.1. - Production
With the Partitioning, OLAP and Data Mining options SQL>
将 REMOTE_LOGIN_PASSWORDFILE 参数设置为 NONE 并重新启动数据库
REMOTE_LOGIN_PASSWORDFILE 参数有三个值:
NONE:禁止使用口令登陆
EXCLUSIVE:主要是针对于多实例来说的,如果数据库是多实例的,也就是RAC,只允许某个单实例使用口令文件
SHARE:主要是针对于多实例来说的,如果数据库是多实例的,也就是RAC,允许所有的实例共享使用一个口令文件
alter system set REMOTE_LOGIN_PASSWORDFILE=NONE scope=spfile
startup force
使用口令实用程序orapwd创建口令文件
orapwd file=filename password=password entries=max_users
其中:
filename 是口令文件的名称
password 是 SYSOPER 和 SYSDBA 的口令
Entries 是允许以 SYSDBA 或 SYSOPER 身份连接的最大不同用户数
如果超出了此数值,必须创建新口令文件,使用较大的数值比较保险
等号 (=) 字符两边没有空格
orapwd file=$ORACLE_HOME/dbs/orapworcl password=a entries= alter system set REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE SCOPE=SPFILE; startup force
使用在创建的口令文件连接到数据库
CONNECT sys/a@orcl AS SYSDBA
ORACLE模拟临时文件、日志成员、口令文件丢失情况与恢复【weber出品】的更多相关文章
- ORACLE调度之基于事件的调度(二)【weber出品】
一.回顾 调度分基于时间的调度和基于事件的调度. 稍微复习一下前面的只是请浏览:<ORACLE调度之基于时间的调度(一)[weber出品]> 二.知识补充 1.队列:一种数据结构,就像一根 ...
- ORACLE调度之基于时间的调度(一)【weber出品】
一.调度的概述 这里我看到一篇对调度的概述觉得描述的比我好,但仅限于概述部分,其他部分我觉得我讲的比他好,于是发生以下事情: ************************华丽的转载******** ...
- ORACLE网络配置大全没有比这个更详细的【weber出品】
一.起篇 现在怎么说也是互联网时代,数据库也要联网,很多朋友学习Oracle的时候无外乎搭建的是以下两种学习环境: 1.直接在windows环境下安装Oracle后直接sqlplus连接. 2.在wi ...
- Oracle 口令文件:即 oracle密码文件
一:文件路径位置 [oracle@localhost db_1]$ cd $ORACLE_HOME/dbs [oracle@localhost dbs]$ ls dbsorapwPROD1 hc_or ...
- DG备库无法接受主库归档日志之密码文件
DG备库无法接受主库归档日志之密码文件 实验目的:还原某个客户案例,客户审计需要,对主库sys用户进行锁定,一小时后对sys用户进行解锁后,发现备库无法接受主库的归档日志 本篇文章,测试sys用户与D ...
- Oracle的sqlnet.ora与password文件试验
先看有没有sqlnet.ora [oracle@localhost ~]$ cd $ORACLE_HOME[oracle@localhost dbhome_1]$ cd network[oracle@ ...
- Oracle控制文件丢失,日志文件丢失
控制文件丢失: alter database backup controlfile to traces; shutdown immediate; @j:\db\script\orcl_ora_ctl_ ...
- Oracle OS认证 口令文件 密码丢失处理
Oracle OS认证 口令文件 密码丢失处理 分类: Oracle Basic Knowledge2009-10-19 14:24 5031人阅读 评论(9) 收藏 举报 oracleos数据库sq ...
- 【恢复】Redo日志文件丢失的恢复
第一章 Redo文件丢失的恢复 1.1 online redolog file 丢失 联机Redo日志是Oracle数据库中比较核心的文件,当Redo日志文件异常之后,数据库就无法正常启动,而且有丢 ...
随机推荐
- php知识点总结(待续)
function_exist()如果没有函数,返回空. is_string($str) 如果$str是布尔型的值,返回为空.是返回1,错误返回空is_array() 同上 字符串输出时,加逗号就自动空 ...
- 在线支付接口之PHP支付宝接口开发简单介绍
php100:92:在线支付接口之PHP支付宝接口开发 支付接口一般是第三方提供的代收款.付款的平台,可以通过支付接口帮助企业或个人利用一切可以使用的支付方式.常见支付平台:支付宝.快钱.云网支付.财 ...
- 19个非常有用的 jQuery 图片滑动插件和教程
jQuery 是一个非常优秀的 Javascript 框架,使用简单灵活,同时还有许多成熟的插件可供选择.其中,最令人印象深刻的应用之一就是对图片的处理,它可以让帮助你在你的项目中加入精美的效果.今天 ...
- OpenStack点滴03-Neutron
OpenStack Neutron是一个比较复杂的组件,如果说OpenStack安装部署过程哪一个组件最麻烦,那就肯定是网络组件Neutron了. 因为我对OpenStack网络这块也不是很熟,就把我 ...
- OpenStack JEOS 镜像
JEOS:Just Enough Operating System 维基百科地址:http://en.wikipedia.org/wiki/Just_enough_operating_system O ...
- web登录与授权
web开发已经流行了很多年,登录与授权也基本有一套通用的流程,下面是我自己常用的登录与授权方式,欢迎大家讨论与吐槽. 概念: 登录是过程,授权是结果.登录只是为了获得页面的访问权限 or 操作权限 o ...
- MSP430 中断优先级
MSP430的中断优先级.打开关闭.中断嵌套 优先级顺序从高到低为: PORT2_VECTOR (1 * 2u) /* 0xFFE2 Port 2 */ PORT1_VECTOR (4 * ...
- z-index的最大值、最小值
浏览器 最大值 超过最大值后变成 最小值 小于最小值后变成 备注 IE6 2147483647 2147483647 -2147483648 -2147483648 IE7 2147483647 ...
- XJOI网上同步测试DAY14 T3
思路:tarjan把桥找出来,然后缩点,注意这里的缩点是:如果两个点之间的连边不是桥,那么就把他们缩起来,然后用一个lct维护,对于每个询问,如果官道连接的是两个联通块的话,就把他们连起来,否则我们就 ...
- hadoop深入研究:(十八)——Avro schema兼容
转载请写明来源地址:http://blog.csdn.net/lastsweetop/article/details/9900129 所有源码在github上,https://github.com/l ...