美文网首页Oracel基础
(转)Oracle中数据文件大小及数量限制

(转)Oracle中数据文件大小及数量限制

作者: 千幻流光 | 来源:发表于2018-08-29 12:15 被阅读1次

本文为转载,内容来源于网络。

原文作者:bfc99,徐曼曼
原文链接:

  1. https://www.linuxidc.com/Linux/2014-01/94979.htm
  2. https://blog.csdn.net/xindiai/article/details/79025959

在Oracle中,数据库是由实例和物理存储结构组成的。而物理存储结构是指存储在磁盘上的物理文件,包括数据文件(data file)、控制文件(control file)、联机重做日志(online redo log)、参数文件(spfile/pfile)、警告日志(alert log)、跟踪文件(trace file)等众多作用不同的文件所组成的。

我们最关注的数据,则是保存在数据文件(data file)中。
(延伸阅读:《Oracle的逻辑存储结构》)

那我们在创建以及维护数据库时,该如何规划数据文件的大小和数量呢?这里面涉及较多的考量因素。主要有如下几点:

  1. 操作系统的限制
  2. ORACLE数据库的限制
  3. 参数DB_FILES的限制
  4. 性能和便利性影响

尝试分别简述如下:
1、操作系统的限制

数据库是运行在操作系统之上的,操作系统是基础,因此,操作系统所能支持的最大文件容量和数量就成为数据库所能支持的限制。但不同操作系统之间,这个限制也是不同的。

常见操作系统对此的限制:
WINDOWS
最大数据块:16K
最大文件数量:20000个(数据块2K时)/40000个(数据块4K时)/65536个(数据块为8K或16K时)
最大文件容量:4GB(文件系统为FAT时)/ 64GB(文件系统为NTFS时)

UNIX和LINUX
最大数据块:32K (LINUX_X86为16K)
最大文件数量:65534个
(转载备注:以上数据未验证)

延伸阅读:《查看操作系统块大小》

2、ORACLE数据库的限制

每个数据库可管理的最大文件数量:65533个。
每个表空间可管理的最大文件数量:取决于操作系统可同时打开的文件数量(通常是1022个)。
每个数据文件的最大容量:该值等于 数据块大小 * 最大可管理的数据块数量。

其中,数据块的大小最大不超过32K,一般取值是8K;可管理的数据块数量是2的22次方减1,约等于4M个块。因此,对于一个数据块大小为8K的数据文件,其最大不能超过32G。但是,若操作系统支持的单个文件最大容量小于此值,则以操作系统的最大容量为限。

3、参数DB_FILES的限制

参数DB_FILES指定了一个实例可以创建的最大文件数量。
这个值可以被修改,但只有重启实例后,才会生效。
DB_FILES设置得过低,可能造成不成添加新的数据文件的问题。设置得过高,会消耗更多的内存资源。

4、性能和便利性影响

  • 通过事先设计,将同一表空间内经常访问的对象放置在不同的数据文件中,并将这些数据文件放置到不同的磁盘通道上,可以改善I/O吞吐量。
  • 将经常改变的数据和不变的数据,放置到不同的数据文件中,备份时,可以只对改变的数据文件进行备份,从而减少备份和恢复的时间。

:从ORACLE 10g起,引入了大表空间的技术。所谓大表空间就是该表空间仅由1个数据文件组成。其优点有:

  • 显著增加了存储容量。

大表空间可管理的数据块数量由传统的小表空间的2的22次方,提升到2的32次方。
在同样采用8K大小的数据块大小时,其最大可管理空间为32T。

  • 减少了数据库所需的数据文件的数量。
  • 简化数据库管理。

====================================

  1. Oracle表空间数据文件大小的限制

由于Oracle的Rowid使用22位来代表数据块号,因此Oracle表空间数据文件每个数据文件最多只能包含2^22个数据块,也因此数据库表空间的数据文件的大小存在上限。文件上限大小为 Block_size*2^22。

数据库块大小 单个文件最大容量
4K 16G
8K 32G
16K 64G
32K 128G

为了解决数据文件大小的问题,Oracle10g专门引入了bigfile tablespace,在bigfile tablespace里Oracle使用32位来存储block号,即比之前增大了1024倍,其最大文件大小从128G增加到128T。当然如果使用bigfile tablespace,则需要注意OS的文件大小限制。

文件系统 最大文件容量
FAT16 2G
FAT32 4G
NTFS 64GB
NTFS5.0 2TB

另外需要注意的是,对于bigfile tablespace来说,只允许创建一个datafile,而不允许再添加datafile。

  1. 当表空间不足时
    (1)设置文件的自增长
    (2)增加数据文件
    (3)添加表空间创建表分区

====================================

在Oracle日常运维中,考虑到如果单个文件很大,恢复起来会比较费时间,因此通常情况下都是把单个数据文件设成8G一个。如果表空间较大的话,可以多添加几个数据文件。
因为单个表空间最大支持1022个数据文件,所以这种情况下可以最大支持到 1022*8G = 8176G ≈ 8T大小的表空间,通常情况下是够用了。

相关文章

  • (转)Oracle中数据文件大小及数量限制

    本文为转载,内容来源于网络。 原文作者:bfc99,徐曼曼原文链接:https://www.linuxidc.co...

  • ORACLE调整数据文件大小

    @ORACLE调整数据文件大小 调整数据文件大小的SQL SQL来源于网络,但是没保存下原作者的连接,在原作者的基...

  • 2019-03-20

    关于旅服二期Oracle转Mysql讨论 1.数据库介绍 ORACLE 属于甲骨文公司,商业数据库,行业中占据相当...

  • 简单的上传附件

    前台:1、ajax 2、formdata 3、修改php.ini post请求文件大小限制和附件文件大小限制(...

  • 增加ORACLE表空间操作

    查询用户对应的表空间,我们可以看到针对不同的数据库用户Oracle 查询用户的对应的数据文件,以及数据文件大小 用...

  • 永久免费的语音转字幕网站介绍

    永久免费的语音转字幕网站介绍 基于百度语音技术,识别率97% 无时长限制,无文件大小限制 永久免费,简单,易用,速...

  • Oracle约束

    什么是约束?约束是Oracle提供的自动保持数据库完整性的一种方法,它通过限制字段中数据、记录中数据和表之间的数据...

  • 锁的详解

    1、Oracle锁类型 锁的作用:保护数据、并发(Oracle 可以并发,因为有锁;因为有锁,限制并发) la...

  • QGIS连接oracle中的clob字段(符合图形的wkt格式)

    1.oracle表中数据 2. 打开qgis toolbox 3. wkt转几何图形 4. 转换后的数据中包含几...

  • Oracle 11g R2 Rman备份与恢复

    Oracle 11g R2 Rman备份 备份与恢复的定义及分类 备份的定义及分类: 备份就是把数据库复制到转储...

网友评论

    本文标题:(转)Oracle中数据文件大小及数量限制

    本文链接:https://www.haomeiwen.com/subject/awrfwftx.html