Oracle 11g中实现自我调整功能

如何让数据库能够实现自我调整,减轻数据库管理员的工作量,是甲骨文公司一直追求的目标。毕竟其数据库的复杂程度远远超出同类数据库;而且,其数据库的维护成本也比其他数据库要高出不少。所以,甲骨文公司追求Oracle数据库的自我调整与优化,降低Oracle数据库的维护成本,也是可以理解的。

自我调整SGA与自我调整检查点,虽然是Oracle数据库10G版本中的新增功能,但是,在11G的版本中,才真正发挥到极致,被数据库管理员充分肯定并积极采纳。下面笔者结合实际的工作经验,带领大家一起看看,这两个新特性,是如何帮助企业降低维护成本,提高数据库的管理效率的。

一、 自我调整检查点

在以前的文章中,笔者谈到过,Oracle数据库中有存储缓冲区,其包括三部分内容,一种叫做脏缓冲存储区。这个缓冲存储区中存储的是已经被修改的数据。一般情况下,这个数据不会马上被写入到数据文件中去。除非空闲缓冲快用完了,这个数据才会被写入数据文件。但是,如此的话,也会遇到一个问题,若空闲缓冲区刚用完的时候,其他用户也在频繁的对数据库进行读写操作,在这个繁忙的时刻,再往数据库文件中写入更改后的数据,那么,很明显,会极大的影响数据库的性能。

所以,作为数据库管理员,我们的设想是能否在I/Q操作比较空的时候,就把脏缓冲中的数据写入到数据库中去呢?这若是靠数据库管理员手工管理肯定不现实,我们数据库有这个自动判断的功能。甲骨文好像听到了我们众多数据库管理员的呼声,在10G版本的数据库中新增了这个功能,并在11G版本中进行了完善,这就是自我调整检查点的自我调整功能。

检查点是将内存中修改的数据与数据库中的数据文件同步的手段。Oracle数据库定期将检查点之间修改的数据写入数据文件,这种做法的要求之一是需要服务器有足够的可用内存,以提高为即将进行的操作寻找空闲内存的执行性能。

所以,这个检查点的设置,跟很多参数有关,如服务器的内存等等。虽然在以前的版本中,数据库管理员可以通过设置相关的初始化参数,来指定预期的崩溃恢复时间。但是,实际上,由于这个设置复杂,影响因素众多,所以,很少有数据库管理员会去调整这个参数,而都是采用其默认的设置。

笔者在使用Oracle 11G数据库中,印象最深的是数据库可以自我调整检查点。虽然在10G中也已经提出了这个功能,但是用的总是不怎么顺心。在11G中作了一定的改善,从而使得这个新功能得到了大家的认同。使用数据库的自动检查点调整,数据库就会自动判断数据库的繁忙程度,具体的说是判断I/Q 操作的繁忙程度,数据库会自动在其比较空闲的时候,把脏缓冲期中的内容写入到数据文件中,从而降低对数据库吞吐量所产生的影响,提高数据库的操作性能。

其实,这个检查点的自我调整功能就好像是一个交通警察,当道路繁忙的时候,下班高峰期时,一些打扫卫生的清洁车就不能进入车道;只有到道路比较空闲的时候,清洁车才能进入车道打扫卫生。从而把清洁车对于车道的正常运行的影响降低到最低。

当然,这个改善可能用户一下子还察觉不出来。但是,我们通过数据库日志进行前后的对比,就会发现,两者的差异是很大的。利用了数据库检查点自我调整功能后,数据库的查询性能,特别是查询大量数据的性能,得到了比较显著的改善。

不过,话说回来,数据库的自我调整功能虽然是一个不错的“交通警察”,但是当车真的很多的时候,最好的“交通警察”,也是无能为力。此时,就需要对硬件上的改善,如增加服务器的内存等等。毕竟像数据检查点等自我调整功能只能够改善硬件的利用能力,而不能从本质上提升硬件的容量。

二、 自我调整系统全局区

SGA是一个英文简称,中文的意思是系统全局区。它是一个存储区域,被所有用户所共享。系统全局区内就像是一个个格子,每个格子就是一个存储组件,用来存放为满足每类内存分配需求而使用的内存池。例如用户最近查询过的数据块就会被保存在其中的一个格子里;数据库的结构等变化需求等也会被存储在这些格子中。

现在就遇到一个问题,格子大小的问题。若格子太大,整个格子只装了不到三分之一的内容,那么明显是一种浪费,这些空间本来是可以被用作其他用途的;若格子太小,信息存放不下去了,就又会发生内存分配错误。

如果数据库管理员自己来调整这些格子的大小,那么难度也是可想而知的。因为这些空间的需求量是不确定的,随着业务的不同,其需要的容量也随之改变。所以,数据库管理员希望数据库能够对系统全局区进行动态分配,能够让数据库根据实际的需要量,划分这些格子的存储空间。当然有个前提,就是其不超出总的容量大小。

在Oracle 10G与11G的数据库系统中,增加并完善了这方面的功能,实现了对于系统全局区的动态分配功能。也就是说,我们数据库管理员,只需要制定一个系统全局区的总大小,然后,里面的格子怎么分,就不需要我们关心了。Oracle数据库会自己根据里面居住的客人数量的多少,进行分配。Oracle数据库会担负起在整个系统全局区内部进行优化内存分配对一个重任。数据库有了这个改进之后,这些房间的大小就不是固定的,而是会随着业务量的不同而实现动态的梗概。如此的话,一方面,房间的空间不会被浪费,不会一个房间很挤而其他房间很空;另一方面,也不会因为存储信息的时候因为空间不够而发生内存存储错误。

通过这个自我调整系统全局区的功能,Oracle数据库会智能地对数据库服务器的内存进行合理的分配,提高内存的使用效率,提高数据库的性能。

不过,这两项功能,都提供了自定义的功能,如可以自己定义系统全局区的总大小以及检查点的恢复时间等等。虽然定义起来比较简单,但是,有个问题就是定义多大才使合理的呢?这个很难确定。因为这根据企业应用不同而有所区别,没有什么可以参考的标准。一般情况下,数据库管理员可能需要观测数据库性能达一年以上,才能够取得一个合理的值。所以,笔者的建议是,刚开始的时候,就采取默认的设置。让数据库自己根据服务器的硬件配置,去取得合理的参数。在以后若有必要的时候,再根据相关的信息,去设置一个合理的值。

【编辑推荐】

  1. Oracle 11g R2文档泄露的几点新特性
  2. Oracle PL/SQL过程调试的输出方法
  3. 使用Oracle数据库实现Python数据持久

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/302930.html<

(0)
运维的头像运维
上一篇2025-05-25 00:49
下一篇 2025-05-25 00:50

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注