Maclean’s Oracle Database Tech Blog Archives

  • 【Oracle ASM】Continuing Operations Directory (file #4)

    《【Oracle ASM】ASM FILE NUMBER 3 Active Change Directory》      中我们介绍而来ACD,但是对于长时间运行的操作则简单的ACD不足以描述其变化。 在一些特殊情况下,Continuing Operations Directory (COD)会分配记录来跟踪大的操作并保证其完成。 如果由于进程失败而导致操作没有彻底完成,则恢复进程将查询该COD记录,并要么完成 要么回滚该操作。 一般有2种持续性的操作,分别为 回滚和后台操作。 后台操作一般由ASM实例的后台进程来实施。 其作为diskgroup维护的一部分来完成,而非特殊要求。一个后台操作持续工作,直到其完成或者实例CRASH。 如果实例CRASH,则恢复实例时将需要重启该后台操作。 rebalance diskgroup即是后台操作的一种。 回滚操作类似于数据库事务。 其由ASM前台进程申请启动。 在此操作过程中diskgroup处于非一致的状态。该操作要么全部完成 ,要么全部回滚。长见由数据库实例来引发这些前台操作。如果数据库实例CRASH,ASM前台进程失败,或者出现一些不可恢复的错误,则该操作将被终止。 创建一个文件将会是一个比较好的例子。如果当创建一个文件时若发生错误,则正为该文件分配的空间需要被释放,部分创建的文件也要被删除。 若数据库实例并未提交该创建,则文件必须被删除。如果ASM实例CRASh了,则该工作需要recover实例时完成。   Continuing Operation Directory (COD) 该metadata file 4 中记录的是在单个metadata block中无法完成的操作记录到COD中,这样当ASM instance crash时可以恢复这些操作。例如创建 删除和resize文件,这其中file number 4 blkn=1为KFBTYP_COD_RB  即回滚rollback数据,后面的数据为KFBTYP_COD_DATA。   可回滚的操作opcodes包括:   1 – Create a file…

  • 【Oracle ASM】ASM FILE NUMBER 3 Active Change Directory

    《深入了解Oracle ASM(二):ASM File number 1 文件目录》  《【Oracle ASM】ASM FILE NUMBER #2 DISK Directory》 ASM FILE NUMBER 3中存放的是Active Change Directory,其作用在于维护对于一个或者多个metadata block的原子性变化,ASM的redo log record 会写入到Active Change Directory(COD)中。 log record是通过单一IO写出的。每一个ASM实例会为ACD分配42个AU的区域来存放生成的redo。 每一个AU的blkn=0用来存放检查点记录。 检查点记录每3秒被写一次,其描述了当实例crash时应当从哪里开始读取redo。 AU中剩余的部分循环写入redo,这些redo包含了所有metadata block的变化。这一块很像RDBMS的redolog。   ACDC – ACD checkpoint ABA – ACD block address LGE – ACD redo log record BCD – ACD block change descriptor    …

  • 诗檀软件Oracle数据库服务方案

    我们欢迎Oracle数据库产品最终使用者(甲方)以及各地集成商,代理商,运维服务商与我们联络,我们提供针对第三方服务商(乙方)的数据库高级二线支持   诗檀软件 Oracle DBA 服务方案   服务 远程服务(无现场) 远程服务+现场服务 关键业务数据库服务(VIP) 服务时间范围 7*24 7*24 7*24 立即远程技术响应 Y Y Y 电话,Email支持 N Y Y 现场救援 N Y Y 定期健康检查 N N Y 升级和补丁建议 N N Y 提供客户关心知识点培训 N N Y 提供根因分析报告 N N Y 专职的客户经理以及工程师 N N Y 紧急救援协议保证 Y Y Y 最短签约周期 3个月 3个月 3个月…

  • 【Oracle ASM】ASM FILE NUMBER #2 DISK Directory

    之前介绍了《深入了解Oracle ASM(二):ASM File number 1 文件目录》 ,  接着我们介绍ASM file number 2 DISK directory。 file number 2 DISK directory存放了已经加入到diskgroup中的DISK信息。虽然很多信息是对AUN=0 blkn=0的重复,但是此处还存放了一些状态信息。如果某个磁盘失败了,则该信息会存放在DISK directory和PST中,但并不直接记录在DISK HEADER。   可以通过SQL来获得FILE NUMBER 2的位置信息,当然也可以通过KFED 读FILE NUMBER 1来获得:   SQL> SELECT xnum_kffxp “Extent”, au_kffxp “AU”, disk_kffxp “Disk” from x$kffxp 2 WHERE group_kffxp=1 and number_kffxp=2 3 and xnum_kffxp <> 2147483648; Extent AU Disk ———- ———- ———- 0…

  • MLOG$表和Snapshots的管理

    下载MLOG$表和Snapshots的管理      

  • 【Oracle数据恢复】ORA-01122,ORA-01110,ORA-01200错误解析

    偶尔我们会遇到ORA-01122,ORA-01110,ORA-01200错误,例如:   ORA-01122: database file 9 failed verification check ORA-01110: data file 9: ‘/u02/oradata/orcl/users01.dbf ‘ ORA-01200: actual file size of 64000 is smaller than correct size of 65600 [oracle@mlab2 ~]$ oerr ora 1122 01122, 00000, “database file %s failed verification check” // *Cause: The information in this file is inconsistent with information // from the…

  • 使用Oracle OSW Analyzer工具分析OSWBB日志,并绘制系统性能走势图

    使用Oracle OSW Analyzer工具分析OSWBB日志,并绘制系统性能走势图 下载《使用Oracle-OSW-Analyzer工具分析OSWBB日志,并绘制系统性能走势图1.pdf》

  • 【转】11 个很少人知道但很有用的 Linux 命令

    Linux命令行吸引了大多数Linux爱好者。一个正常的Linux用户一般掌握大约50-60个命令来处理每日的任务。Linux命令和它们的转换对于Linux用户、Shell脚本程序员和管理员来说是最有价值的宝藏。有些Linux命令很少人知道,但不管你是新手还是高级用户,它们都非常方便有用。 这篇文章的目的是介绍一些少有人知的Linux命令,它们一定会高效地帮你管理你的桌面/服务器。   1. sudo !!命令 没有特定输入sudo命令而运行,将给出没有权限的错误。那么,你不需要重写整个命令,仅仅输入’!!‘就可以抓取最后的命令。   ·········10········20········30········40········50········60········ 1.$ apt-get update 2. 3.E: Could not open lock file /var/lib/apt/lists/lock – open (13: Permission denied) 4.E: Unable to lock directory /var/lib/apt/lists/ 5.E: Could not open lock file /var/lib/dpkg/lock – open (13: Permission denied) 6.E: Unable to lock the administration directory (/var/lib/dpkg/), are you root? – ·········10········20········30········40········50········60········ 01.$ sudo !! 02. 03.sudo apt-get update 04.[sudo] password for server: 05.… 06… 07.Fetched 474 kB in 16s…

  • 【转】Linux 中如何打开一个大文本文件

    在“大数据”时代,我们会经常遇到有大文本文件(上 GB 或更大)的情况。假设需要我们手工的搜索和编辑这些大文件,或者为了解决一些特定的问题而需要手工分析多个上 GB 的日志文件。传统的文本编辑软件对处理这样的大文件不太有效,当我们试图打开一个大文件时会经常由于内存不足而郁闷的不行。 如果你是一个精明的系统管理员,你也许会用 cat、tail、grep、sed、awk 等这些命令的组合来打开和编辑一个文本文件。在这篇教程里,我将会谈论关于如何在 Linux 中打开(并编辑)一个大文本文件的更友好的方式方法。 Vim 的 LargeFile 插件   Vim文本编辑器拥有大量的插件(或脚本),它们能扩展 VIM 的功能。其中的一个Vim插件是 LargeFile 插件。 LargeFile 插件可以使大文件更迅速的被加载和编辑,它是通过关闭 VIM 的一些像事件、回退、语法高亮等功能来实现的。 要在 VIM 上安装 LargeFile 插件,首先要确认是否已经安装 VIM。 在 Debian、 Ubuntu 或 Linux Mint 系统中: $ sudo apt-get install vim 在 Fedora、CentOS 或 RHEL 系统中: $ sudo yum install vim-enhanced 可以从 Vim website 上下载 LargFile 插件,最新版本号是5,下载的文件将会保存为…

  • 【Oracle ASM】新增ASM DISK遇到ORA-15080、ORA-15038等错误

    SQL> alter diskgroup data add disk ‘/dev/asmc-disk11’; alter diskgroup data add disk ‘/dev/asmc-disk11’ * ERROR at line 1: ORA-15032: not all alterations performed ORA-15038: disk ” mismatch on ‘Sector Size’ with target disk group [4096] [512] SQL> create diskgroup TESTDG1 EXTERNAL REDUNDANCY DISK ‘/dev/asmc-disk11’ ATTRIBUTE ‘compatible.asm’ = ‘11.2’, ‘compatible.rdbms’ = ‘11.2’, ‘sector_size’=’4096’; create diskgroup TESTDG1…