数据文件OS块的大小
在前一个BLOG里面说到了怎么计算数据文件的大小,ls –l /8192-1,其实这里的8192是不正确的,只是通用情况下是这样的,下面是MOS给的官方文档,关于每种平台下面的OS块的大小
欢迎大家加入ORACLE超级群:17115662 免费解决各种ORACLE问题,以后BLOG将迁移到http://www.htz.pw
How an Oracle block# is mapped to a file offset (in bytes or OS blocks) (文档 ID 761734.1)
修改时间:2011-2-15
类型:HOWTO
In this Document
Goal
Solution
Generic Platform Formula:
Alternate Platform Specific Formula (i.e. AIX and HP Tru64):
APPLIES TO:
Oracle Server - Enterprise Edition - Version: 10.2.0.1 to 11.1.0.8 - Release: 10.2 to 11.1
Oracle Server - Enterprise Edition - Version: 10.2.0.1 to 11.1.0.8 [Release: 10.2 to 11.1]
Information in this document applies to any platform.
GOAL
This document is about how an Oracle block number is mapped to a file offset (in bytes or OS blocks) for Generic OS platforms and includes an alternate formula for specific OS platforms like AIX and HP Tru64. These are the only 2 platforms where the Volume Manager reserves space for Metadata in the Oracle datafile.
For Oracle 10g and 10gR2 there are only two platforms with logical volume Metadata on raw devices: AIX and HP Tru64.
HP Tru64 is no longer supported on Oracle 11g, so AIX is the only one in 11g.
SOLUTION
Every Oracle file has an Operating System file header block ("BLOCK 0") created and maintained by Oracle, which is the size of a standard Oracle block. If multiple block sizes are being used then V$DATAFILE.BLOCK_SIZE should be queried for the file# in question.
"BLOCK 0" can be know as the "Oracle OS Header Block" or "Database Block# 0".
"BLOCK 1" is the Oracle Header Block that contains generic information for the File.
From the documentation: V$DATAFILE.BLOCK1_OFFSET is the "Offset from the beginning of the file to where the Oracle generic information begins.".
"BLOCK 1" offset = v$datafile.block1_offset
V$DATAFILE.BLOCK1_OFFSET do not make much sense for ASM. The value displayed is UB4MAXVAL (4-byte unsiged int max) for ASM when it cannot be computed.
Generic Platform Formula:
A general formula to locate the byte offset in any platform is:
block1_offset = v$datafile.block1_offset
oracle_block_size = v$datafile.block_size
offset = block1_offset + (oracle_block_number - 1) * oracle_block_size
Another way to calculate this offset is using the platform specific information:
Alternate Platform Specific Formula (i.e. AIX and HP Tru64):
Platform specific formula for a file offset to locate an Oracle block in a RAW Device:
offset = raw_device_block0_offset + (oracle_block_number * oracle_block_size)
AIX:
On AIX raw device, the logical volume metadata uses 4096 bytes. That would be the block0_offset on this platform. On HP Tru64 it is 65536 bytes.
raw_device_block0_offset = 4096
file_system_block0_offset = 0
Example:
Calculate the byte offset using the platform specific formula for block 30 in a RAW Device in AIX
oracle_block_size = 8192 (v$datafile.block_size)
oracle_block_number = 30
AIX raw_device_block0_offset = 4096
offset = 4096 + (30*8192) = 249856
Notes:
The above formulas are given in bytes.
file_system_block#_offset refers to any file systems like veritas, zfs, etc.
raw_device_block0_offset is the byte offset to locate the Oracle "BLOCK 0" in a raw device.
file_system_block0_offset is the byte offset to locate the Oracle "BLOCK 0" in a file system.
Formula To produce an offset in 4096 blocks in a RAW device in AIX:
offset <in 4096 blocks> = 1 + (oracle_block_number*(oracle_file_block_size/4096))
HP Tru64:
For HP Tru64 use:
raw_device_block0_offset = 65536
file_system_block0_offset = 0
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
数据文件OS块的大小
下载Word文档到电脑,方便收藏和打印~
猜你喜欢
mysql怎么查看数据文件大小
oracle怎么查看数据库文件大小
云服务器如何选大小的数据文件
关于Python OS模块常用文件/目录函数详解
云服务器如何选大小的数据文件夹
云服务器如何选大小的数据库文件
Shell脚本创建指定大小文件的测试数据
云服务器如何选大小的数据文件格式
Python递归文件中os模块的实际应用方式
云服务器如何选大小的数据库文件夹
python文件目录操作之os模块的示例分析
MySQL删除数据,表文件大小依然没变的原因
云服务器如何选大小的数据库文件格式
云服务器如何选大小的数据文件夹名称
编程热搜
[mysql]mysql8修改root密码
use mysqlselect * from user where user="root";update user set password=password("mysql@2020") where user="root";ERROR 1064 (42000)MySQL专题3之MySQL管理
1、启动以及关闭MySQL服务器- 首先,我们需要通过以下命令来检查MySQL服务器是否已经启动:ps -ef | grep mysqld- 如果MySQL已经启动,以上命令将输出mysql进程列表,如果mysql未启动,你可以使用以下
编程资源站
- 资料下载
- 历年试题
目录
反馈
我要
反馈