ORA-01148: cannot refresh file size for datafile *

1 版本信息

  • 操作系统版本:
-bash-3.00$ uname -a
SunOS boss-db1 5.10 Generic_138888-06 sun4u sparc SUNW,SPARC-Enterprise
  • 数据库版本:
SQL> select * from v$version;

BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi
PL/SQL Release 10.2.0.4.0 - Production
CORE 10.2.0.4.0 Production
TNS for Solaris: Version 10.2.0.4.0 - Production
NLSRTL Version 10.2.0.4.0 - Production

2 错误信息

ORA-01110: data file 254: '+DATA2/so_35.dbf'
ORA-00376: file 254 cannot be read at this time

3 收集错误信息

  • 查找数据库trace信息
-bash-3.00$ cd $ORACLE_BASE/admin/boss/bdump
-bash-3.00$ grep -i so_35 ./*
./boss1_dbw0_25404.trc:ORA-01110: data file 254: '+DATA2/so_35.dbf'
./boss1_dbw0_25404.trc:file 254: +DATA2/so_35.dbf
./boss1_diag_25354.trc: fname=+DATA2/so_35.dbf
  • 确认文件的最后修改时间与问题出现时间一致
-bash-3.00$ ls -la boss1_dbw0_25404.trc
-rw-rw---- 1 oracle oinstall 442294 Apr 14 15:25 boss1_dbw0_25404.trc
  • 查看trace提供的信息
........(省略)
{***} 2017-04-14 15:20:05.747
ORA-01148: cannot refresh file size for datafile 254
ORA-01110: data file 254: '+DATA2/so_35.dbf'
ORA-09817: Write to audit file failed.
SVR4 Error: 28: No space left on device =========================> 审计文件所在路径为$ORACLE_BASE/admin/$ORACLE_SID/adump, 空间充足
Automatic datafile offline due to media error on =========================> 数据文件被offline
file 254: +DATA2/so_35.dbf
........(省略)

4 故障恢复

  • 查看文件状态
SQL> COL FILE_NAME FOR A40
SQL> SELECT FILE_NAME,STATUS,BYTES FROM DBA_DATA_FILES WHERE FILE_ID=254; FILE_NAME STATUS BYTES
---------------------------------------- --------- ----------
+DATA2/so_35.dbf AVAILABLE =======================================> 文件大小为空! SQL> COL NAME FOR A17
SQL> SELECT FILE#,STATUS,ERROR,RECOVER,FUZZY,BYTES,NAME FROM V$DATAFILE_HEADER WHERE FILE#=254; FILE# STATUS ERROR REC FUZ BYTES NAME
---------- ------- ------------------------------ --- --- ---------- -----------------
254 OFFLINE NO YES 1.8765E+10 +DATA2/so_35.dbf ====> status=offline 与trace文件中处理结果一致。
这里我们可以看到文件本身的状态是available,但是文件头已经是offline状态,与trace 文件内容一致。
  • 尝试恢复数据文件
SQL> ALTER DATABASE RECOVER DATAFILE 254;

Database altered.
  • online 数据文件
SQL> ALTER DATABASE DATAFILE 254 ONLINE;

Database altered.

SQL> SELECT FILE_NAME,STATUS,BYTES FROM DBA_DATA_FILES WHERE FILE_ID=254;

FILE_NAME                                STATUS         BYTES
---------------------------------------- --------- ----------
+DATA2/so_35.dbf AVAILABLE 1.8765E+10 ===========================================> 文件大小已正常刷新!
NOTES
数据库最好是在归档状态,如果问题处理不及时,redo 文件被覆盖而又没有开启归档,这种处理方式不会奏效的.

5 问题总结

从现象上来看,是由于物理磁盘空间不足引起的。此问题,目前发现的,只有10G,SUNOS 操作系统中会出现。
经确认,此问题,属于BUG(Bug 9357097),在数据库版本11.2.0.2 之后得以解决。

6 建议

由于此BUG Oracle官方未提供任何补丁及规避方案。因此,将数据库最低升级至11.2.0.4 版本,以避免Oracle 10G 中诸多BUG.

7 高屋建瓴

数据库,是一个超级复杂的程序,里面的各种逻辑关系,让人想起来就头皮发麻。在一个复杂到要一个人花数年时间去研究其中的逻辑的程序中,肯定会存在各种各样的问题,包括尚未完善的甚至是缺失的功能。
Oracle官方在这一点上也做的不错,就是在推广应用、维护的过程中,收集问题,处理问题,优化逻辑,收集BUG,弥补过失。尽力使自己的产品功能完善,减少问题,并尽力跟随世界发展的趋势.
毕竟这样一个庞大的数据库想要做体系架构的变动实在是难。
新的版本数据,解决了旧版本中各种的BUG,新添加了很多的增强的功能,一方面使数据库性能得以提升,同时,更加便于维护管理。
那么我们的客户使用对方的产品,我们作为Oracle的一个合作商,是否有这种魄力,推动客户去做数据库升级呢?而同时,这会又是一个新的项目基点。
哪怕没有此种问题,我们是否有向客户提供打补丁的建议?以提高客户满意度?

Author: AsiaInfo Techenology(China) Co. Ltd. 部门: PMO 工程师:李海波

Created: 2019-06-22 Sat 11:47

Validate

ORA-01148:cannot refresh file size for datafile ***的更多相关文章

  1. ORA-27092: size of file exceeds file size limit of the process

    停数据库时遇到下述问题: $ ./addbctl.sh stop You are running addbctl.sh version 120.1 Shutting down database UAT ...

  2. [Intellij IDEA]File size exceeds configured limit(2560000). Code insight features are not available

    在使用 IDEA, 发现一个问题File size exceeds configured limit (2560000). Code insight features not available.

  3. How to calculate a good InnoDB log file size

    Peter wrote a post a while ago about choosing a good InnoDB log file size.  Not to pick on Peter, b ...

  4. [Mon Feb 10 15:21:06 2014] [notice] child pid 7101 exit signal File size limit exceeded (25)

    今天遇到的问题: LAMP的LOG里报如下错误. 然后IE和FIREFOX里显示连接被重置或是无法访问. 但自己建一个正常的PHP测试探针倒可以. 原来是PHP错误日志太多,无法写入LOG导致. [r ...

  5. Github 修正上传时“this exceeds GitHub’s file size limit of 100 MB”错误

    自己的项目的版本控制用的是Git,代码仓库在github托管.项目里用到了IJKMediaFramework 想把代码push到github上,结果出错了,被拒绝,具体信息是: Total 324 ( ...

  6. 值得一提:关于 HDFS 的 file size 和 block size

    转 http://blog.csdn.net/samhacker/article/details/23089157?utm_source=tuicool&utm_medium=referral ...

  7. ES部署报错 max file size 和 kibana 报错File size limit exceeded

    启动失败一 ERROR: [2] bootstrap checks failed [1]: max file descriptors [4096] for elasticsearch process ...

  8. linux下core file size设置笔记

    现象说明:突然发现一台测试机器的java程序莫名其妙地没了,但是没有core dump!这就需要打开服务器的core文件生成的功能了,(即core dump文件),方便程序调试.1)core文件简介c ...

  9. 解决访问 jar 包里面的字体报错:OTS parsing error: incorrect file size in WOFF header

    前言:jar 包里面的字体加载,浏览器 console 中报警告信息,这里记录一下解决方案. 附:自己的一个 jar 包源码 https://github.com/yuleGH/querydb 错误问 ...

随机推荐

  1. python网络编程:socket半连接池、UDP通讯模板

    一.TCP半连接池原理 二.UDP通讯 三.UDP聊天 四.UDP聊天2 五.UDP会粘包吗 六.UDP总结 七.UDP与TCP对比 一.TCP半连接池原理 客户端 import socket cli ...

  2. 【Swing】图形用户界面基础

    前言 简单总结一下图形用户界面(Graphical User Interface)的相关基础,如GUI的基本元素:窗口,以及介绍Java中的图形界面开发设计的技术. 图形用户界面 图形用户界面就是以图 ...

  3. PAT Basic 1023 组个最小数 (20 分)

    给定数字 0-9 各若干个.你可以以任意顺序排列这些数字,但必须全部使用.目标是使得最后得到的数尽可能小(注意 0 不能做首位).例如:给定两个 0,两个 1,三个 5,一个 8,我们得到的最小的数就 ...

  4. E - We Need More Bosses CodeForces - 1000E (tarjan缩点,树的直径)

    E - We Need More Bosses CodeForces - 1000E Your friend is developing a computer game. He has already ...

  5. Redis主从复制配置+哨兵模式

    架构设计: master:s0 slave:s1.s2 主机映射信息如下: 192.168.32.100 s0 192.168.32.101 s1 192.168.32.102 s2 1.安装Redi ...

  6. Vue数据通信详解

    如果有需要源代码,请猛戳源代码 希望文章给大家些许帮助和启发,麻烦大家在GitHub上面点个赞!!!十分感谢 一.前言 组件是 vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着 ...

  7. jenkins发送jemter邮件附件格式配置

    原文:https://www.cnblogs.com/chenchen-tester/p/6930200.html build.xml <?xml version="1.0" ...

  8. 获取网卡速率,cpu使用率

    ];//获取网卡名称 PerformanceCounter NetworkR = new PerformanceCounter("Network Interface", " ...

  9. Luogu P4139 上帝与集合的正确用法

    题目链接:Click here Solution: 这道题就考你会不会扩展欧拉定理,根据扩展欧拉定理可知 \[ a^b \equiv a^{(b\,mod\,\varphi(p))+\varphi(p ...

  10. Spring——代理实现AOP

    一.静态代理实现 1.接口(抽象主题) 2.接口的实现类(真实主题) 3.代理类(代理主题) 4.测试类: ApplicationContext context=new ClassPathXmlApp ...