本文为转载,内容来源于网络。
原文作者:bfc99,徐曼曼
原文链接:
在Oracle中,数据库是由实例和物理存储结构组成的。而物理存储结构是指存储在磁盘上的物理文件,包括数据文件(data file)、控制文件(control file)、联机重做日志(online redo log)、参数文件(spfile/pfile)、警告日志(alert log)、跟踪文件(trace file)等众多作用不同的文件所组成的。
我们最关注的数据,则是保存在数据文件(data file)中。
(延伸阅读:《Oracle的逻辑存储结构》)
那我们在创建以及维护数据库时,该如何规划数据文件的大小和数量呢?这里面涉及较多的考量因素。主要有如下几点:
- 操作系统的限制
- ORACLE数据库的限制
- 参数DB_FILES的限制
- 性能和便利性影响
尝试分别简述如下:
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。
- 减少了数据库所需的数据文件的数量。
- 简化数据库管理。
====================================
- 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)设置文件的自增长
(2)增加数据文件
(3)添加表空间创建表分区
====================================
在Oracle日常运维中,考虑到如果单个文件很大,恢复起来会比较费时间,因此通常情况下都是把单个数据文件设成8G一个。如果表空间较大的话,可以多添加几个数据文件。
因为单个表空间最大支持1022个数据文件,所以这种情况下可以最大支持到 1022*8G = 8176G ≈ 8T大小的表空间,通常情况下是够用了。