SGA是一个英文简称,中文的意思是系统全局区。它是一个存储区域,被所有用户所共享。系统全局区内就像是一个个格子,每个格子就是一个存储组件,用来存放为满足每类内存分配需求而使用的内存池。例如用户最近查询过的数据块就会被保存在其中的一个格子里;数据库的结构等变化需求等也会被存储在这些格子中。
现在就遇到一个问题,格子大小的问题。若格子太大,整个格子只装了不到三分之一的内容,那么明显是一种浪费,这些空间本来是可以被用作其他用途的;若格子太小,信息存放不下去了,就又会发生内存分配错误。
如果数据库管理员自己来调整这些格子的大小,那么难度也是可想而知的。因为这些空间的需求量是不确定的,随着业务的不同,其需要的容量也随之改变。所以,数据库管理员希望数据库能够对系统全局区进行动态分配,能够让数据库根据实际的需要量,划分这些格子的存储空间。当然有个前提,就是其不超出总的容量大小。
在Oracle 10G与11G的数据库系统中,增加并完善了这方面的功能,实现了对于系统全局区的动态分配功能。也就是说,我们数据库管理员,只需要制定一个系统全局区的总大小,然后,里面的格子怎么分,就不需要我们关心了。Oracle数据库会自己根据里面居住的客人数量的多少,进行分配。Oracle数据库会担负起在整个系统全局区内部进行优化内存分配对一个重任。数据库有了这个改进之后,这些房间的大小就不是固定的,而是会随着业务量的不同而实现动态的梗概。如此的话,一方面,房间的空间不会被浪费,不会一个房间很挤而其他房间很空;另一方面,也不会因为存储信息的时候因为空间不够而发生内存存储错误。
通过这个自我调整系统全局区的功能,Oracle数据库会智能地对数据库服务器的内存进行合理的分配,提高内存的使用效率,提高数据库的性能。
不过,这两项功能,都提供了自定义的功能,如可以自己定义系统全局区的总大小以及检查点的恢复时间等等。虽然定义起来比较简单,但是,有个问题就是定义多大才使合理的呢?这个很难确定。因为这根据企业应用不同而有所区别,没有什么可以参考的标准。一般情况下,数据库管理员可能需要观测数据库性能达一年以上,才能够取得一个合理的值。所以,笔者的建议是,刚开始的时候,就采取默认的设置。让数据库自己根据服务器的硬件配置,去取得合理的参数。在以后若有必要的时候,再根据相关的信息,去设置一个合理的值。
文章来源于领测软件测试网 https://www.ltesting.net/