热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Oracle配置MultipleBlockSizes表空间

一般来说,我们建库时指定的db_block_size都是使用默认的8k。从这种角度来说,数据库的blocksize都是一样的。但Oracle是可

一般来说,我们建库时指定的db_block_size 都是使用默认的8k。 从这种角度来说,数据库的block size 都是一样的。 但Oracle 是可

一. 参数说明

一般来说,我们建库时指定的db_block_size 都是使用默认的8k。 从这种角度来说,数据库的block size 都是一样的。 但Oracle 是可以配置Multiple Block Sizes的。

SYS@anqing1(rac1)> show parameter cache_size

NAME TYPE VALUE

------------------------------------ -----------------------------------------

db_16k_cache_size big integer 0

db_2k_cache_size big integer 0

db_32k_cache_size big integer 0

db_4k_cache_size big integer 0

db_8k_cache_size big integer 0

db_cache_size big integer 0

db_keep_cache_size big integer 0

db_recycle_cache_size big integer 0

SYS@anqing1(rac1)> show parameter db_block_size

NAME TYPE VALUE

----------------------------------------------- ------------------------------

db_block_size integer 8192

如果要配置Multiple Block Sizes,就需要配置db_nK_cache_size 参数,这些参数默认都是0. 配置完这些参数之后,我们在创建相关的表空间时,就可以指定对应的block。 这样就完成了Multiple Block Sizes。 但是,Multiple Block Sizes 给管理上代理一定的复杂度,所以实际使用的不多。

注意一点:

在创建非db_block_size 标准的表空间时,必须先执行对应的DB_nK_CACHE_SIZE 参数,来创建nK 的buffer,不然会报:

ORA-29339: tablespace block size 4096 does not matchconfigured block sizes

1.1 DB_BLOCK_SIZE


Property


Description



Parameter type


Integer



Default value


8192



Modifiable


No



Range of values


2048(2k) to 32768(32k), but your operating system may have a narrower range



Basic


Yes



Oracle RAC


You must set this parameter for every instance, and multiple instances must have the same value.

Caution:

Set this parameter at the time of database creation. Do notalter it afterward.

DB_BLOCK_SIZEspecifies (in bytes) the size of Oracle database blocks. Typical values are4096 and 8192. The value of this parameter must be a multiple of the physicalblock size at the device level.

Thevalue for DB_BLOCK_SIZE in effect at the time you create the databasedetermines the size of the blocks. The value must remain set to its initialvalue.

ForReal Application Clusters, this parameter affects the maximum value of theFREELISTS storage parameter for tables and indexes. Oracle uses one databaseblock for each freelist group. Decision support system (DSS) and data warehousedatabase environments tend to benefit from larger block size values.

Note:

(1)32-bit operating systems support a maximum DB_BLOCK_SIZE value of16384(16k)--32位系统,db_block_size最大16k

(2)64-bit operating systems support a maximum DB_BLOCK_SIZE value of32768(32k)--64位系统,db_block_size最大32k

1.2 DB_nK_CACHE_SIZE参数

官网的说明如下:

From: #REFRN10027


Property


Description



Parameter type


Big integer



Syntax


DB_[2 | 4 | 8 | 16 | 32]K_CACHE_SIZE = integer [K | M | G]



Default value


0 (additional block size caches are not configured by default)



Modifiable


ALTER SYSTEM



Range of values


Minimum: 0 (values greater than zero are automatically modified to be either the granule size * number of processor groups, or 4 MB * number of CPUs, whichever is greater)


Maximum: operating system-dependent



Basic


No

DB_nK_CACHE_SIZE (where n = 2, 4, 8, 16, 32) specifies thesize of the cache for the nK buffers. You can set this parameter onlywhen DB_BLOCK_SIZE has a value other than nK. For example, ifDB_BLOCK_SIZE=4096, then it is illegal to specify the parameterDB_4K_CACHE_SIZE (because the size for the 4 KB block cache is alreadyspecified by DB_CACHE_SIZE).

-- DB_nK_CACHE_SIZE 参数指定nK 的buffer,在指定cache时,要确保有足够的空间。 不能和DB_BLOCK_SIZE参数冲突,n 可以取2,4,8,16,32.

Donot set this parameter to zero if there are any online tablespaces with an nKblock size.

Operating system-specific block size restrictions apply.For example, you cannot set DB_32K_CACHE_SIZE if the operating system's maximumblock size is less than 32 KB. Also, you cannot set DB_2K_CACHE_SIZE if theminimum block size is greater than 2 KB.

-- DB_nK_CACHE_SIZE要操作系统支持,如果n=32,但操作系统支持,也是不行的。

See Also:

Youroperating system-specific Oracle documentation for more information on blocksize restrictions

二. 测试

--查看db_block_size

SYS@anqing2(rac2)> show parameterdb_block_size

NAME TYPE VALUE

------------------------------------ -----------------------------------------

db_block_size integer 8192

--查看操作系统位数

[root@rac2 ~]# cat /proc/cpuinfo | grepflags | grep 'lm' | wc -l

1

结果大于0, 说明支持64bit计算. lm指long mode, 支持lm则是64bit。

有关CPU的更多信息参考:

Linux CPU 信息查看

--查看db_32k_cache_size值

SYS@anqing2(rac2)> show parameterdb_32k_cache_size

NAME TYPE VALUE

----------------------------------------------- ------------------------------

db_32k_cache_size big integer 0

-- 指定32k 时,报错,提示系统不支持,看来只能用16k了

SYS@anqing1(rac1)> alter system setdb_32k_cache_size=1M scope=both sid='anqing1';

alter system set db_32k_cache_size=1Mscope=both sid='anqing1'

*

ERROR at line 1:

ORA-32017: failure in updating SPFILE

ORA-00382: 32768 not a valid block size,valid range [..]

--指定16k 的cachebuffer

SYS@anqing1(rac1)> alter system set db_16k_cache_size=1M scope=bothsid='anqing1';

System altered.

SYS@anqing2(rac2)> alter system set db_16k_cache_size=1M scope=bothsid='anqing2';

System altered.

-- 因为我的测试环境是RAC,所以在2个节点上都指定了参数

--查看cache,虽然指定了1M,,但系统使用了默认的最小值

SYS@anqing1(rac1)> show parameter db_16k_cache_size

NAME TYPE VALUE

----------------------------------------------- ------------------------------

db_16k_cache_size big integer 4M

SYS@anqing2(rac2)> show parameter db_16k_cache_size

NAME TYPE VALUE

----------------------------------------------- ------------------------------

db_16k_cache_size big integer 4M

-- 这个最小的默认值,上面的官网说明有解释:

--values greater thanzero are automatically modified to be either the granule size * number ofprocessor groups, or 4 MB * number of CPUs, whichever is greater

--指定了16kcache,我们就可以创建block 为16k的表空间了

SYS@anqing1(rac1)> CREATE TABLESPACETest DATAFILE

2 '+DATA/anqing/datafile/test01.dbf' SIZE 50M AUTOEXTEND ON NEXT 10MMAXSIZE 100M BLOCKSIZE 16K;

Tablespace created.

-- 注意这里指定了Blocksize为16k,和我们之前创建的Cache 大小相对应。

--为了验证不指定cache报的错误,我们创建一个4k的tablespace

SYS@anqing1(rac1)> CREATE TABLESPACE TTDATAFILE '+DATA/anqing/datafile/TT01.dbf' SIZE 50M AUTOEXTEND ON NEXT 10MMAXSIZE 100M BLOCKSIZE 4K;

CREATE TABLESPACE TT DATAFILE'+DATA/anqing/datafile/TT01.dbf' SIZE 50M AUTOEXTEND ON NEXT 10M MAXSIZE 100MBLOCKSIZE 4K

*

ERROR at line 1:

ORA-29339: tablespaceblock size 4096 does not match configured block sizes

-- 这里提示了我们:ORA-29339的错误,所以在创建Multiple Block Sizes 之前,必须指定对应的Cache buffer。

--创建一个测试表,放到16k的test 表空间

SYS@anqing1(rac1)> create table tt16k tablespace test as select * from dba_objects;

Table created.

--验证一下表tt16k的block 大小

SYS@anqing1(rac1)> selectsegment_name,blocks from dba_segments where segment_name='TT16K';

SEGMENT_NAME BLOCKS

--------------- ----------

TT16K 384

--当表的每个block越大时,那么它里面就能够存放更多的block

--我们使用8k的block 来创建一个相同的表,来查看它使用blocks,从而进行对比

SYS@anqing1(rac1)> create table tt8k as select * from dba_objects;

Table created.

SYS@anqing1(rac1)> select segment_name,blocks from dba_segments wheresegment_name='TT8K';

SEGMENT_NAME BLOCKS

--------------- ----------

TT8K 768

--看到,使用16k是384个blocks,使用8k是768个blocks。

-- 将tt8kmove 到 test(16k)

SYS@anqing1(rac1)> alter table tt8k move tablespace test;

Table altered.

SYS@anqing1(rac1)>select segment_name,blocks from dba_segments wheresegment_name='TT8K';

SEGMENT_NAME BLOCKS

--------------- ----------

TT8K 384

使用的Blocks 就下降下来了。


推荐阅读
  • Linuxchmod目录权限命令图文详解在Linux文件系统模型中,每个文件都有一组9个权限位用来控制谁能够读写和执行该文件的内容。对于目录来说,执行位的作用是控制能否进入或者通过 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文主要讨论了在xps15上安装双系统win10和MacOS后,win10无法正常更新的问题。分析了可能的引导问题,并提供了解决方法。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 树莓派Linux基础(一):查看文件系统的命令行操作
    本文介绍了在树莓派上通过SSH服务使用命令行查看文件系统的操作,包括cd命令用于变更目录、pwd命令用于显示当前目录位置、ls命令用于显示文件和目录列表。详细讲解了这些命令的使用方法和注意事项。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • Python语法上的区别及注意事项
    本文介绍了Python2x和Python3x在语法上的区别,包括print语句的变化、除法运算结果的不同、raw_input函数的替代、class写法的变化等。同时还介绍了Python脚本的解释程序的指定方法,以及在不同版本的Python中如何执行脚本。对于想要学习Python的人来说,本文提供了一些注意事项和技巧。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
author-avatar
Jenny821010
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有