如何调整Oracle性能

调整Oracle性能:

 1.数据访问机制,如table full scan,index range scan,index full scan,fast index scan等,这些内容让我明白SQL语句与Oracle的交互方式,数据是如何从物理的数据文件返回给界面的,是调整SQL语句必须的知识。

  2.表之间的连接方式,主要是nested loog,hash join,merge sort,明白各个连接方式的运作机制,对于调整多表查询的SQL是必须的

  3.索引结构,理解索引B树的数据分布,和物理表之间是怎样的对应关系,各个DML对索引空间有什么样的影响,在Oracle中还包括了位图索引,函数索引,反向索引

  4.Oracle的空间存储机制,本地表空间管理与字典管理的区别,ASSM特性,表中 freelist,pctfree,pctused,HWM(高水位线)之间有什么样的联系,他们对DML操作的性能影响

  5.Oracle的内存结构,SGA区,包括db_cache,shared_pool,larger_pool,java_pool,PGA 区,对于各个区内部大小的设定,调整,监控等,其中db_cache学习了LRU数据缓冲机制,划分不同块大小的缓冲块,及keep,recycle池的使用,shared_pool包括其内部结构,Bucket划分,绑定变量,SQL查询计划,执行树,硬解析,软解析等,PGA的调整包括大小设定,连接会话的PGA使用情况,磁盘排序等

  6.各种等待事件的调整(OWI),磁盘IO方面的主要是db file sequential read , db file scattered read,direct path read等,这些事件的调整要看其等待的时间长短来进行,因为等待是不可能消失的,根据P1,P2,P3参数可以获取具体等待的数据库对象,结合话话的 SQL,用SQL_TRACE或EXPLAIN做具体调整

  锁定方面(enqueue)主要是判断会话为什么会阻塞,引起阻塞的会话正在执行什么语句,锁定的对象是什么,锁的类型是什么,出现非常频繁的 enqueue等待估计系统的设计存在很大的问题

  锁存器(latch),这个是关于内存的锁定,调整起来比较棘手,需要理解内存的访问,修改,扫描机制,比如偌大一个db_cache区域,他里面的数据是怎样定位的,修改,访问时又是怎样一种互斥的机制来保障内存块的一致性,等等,在9I中,这种机制大致如下,cache中有一定数量的 hash latch,每一个hash latch下面挂载若干个hash bucket,每一个hash bucket下面连接一条hash chain,hash chain的内容就是链接起来的数据块缓存头,这样一个hash latch对应多个hash bucket,每个hash bucket对应一条hash chain,当Oracle要访问某一个块时,他要知道这个块是属于哪个数据文件,他是第几个块,根据这些信息对块做Hash运算,会得到相应的hash bucket内存地址,然后定位到内存中的bucket,再扫描跟着的hash chain,如果找到,则直接使用,如果不能找到,这在hash chain上链接新块,这整个过程的前提是进程必须获取控制这个bucket的latch,如果有多个进程,他们访问的数据块正好hash到相同的 Latch管辖区,将出现针对这个管辖Latch的争用,体现的latch等待就是cache buffer chains.

  再比如buffer busy wait事件,A会话读取数据块C,C不在内存中,将进行磁盘IO,此时B会话也进行C块的读取,那这时会产生C数据块的两次物理IO吗?答安是NO,A 会话会在内存中预留出以容纳C数据块的内存空间,并将他暂时锁定,以便进行随后的磁盘IO,B会话会等待锁定的结束,直到C块被读进内存空间,此时一个 BUFFER BUSY的等待事件就会被记录,当然以后对C块的访问就不会有什么障碍了,因为他已经被缓存了

  其他主要的latch等待包括library cache,shared pool等,关于这部分的学习我推荐Steve Adams编写的Oracle8i Internal Service for Waits,Latches,Locks and Memory,世界顶尖级高手的杰作,不看可惜,英文不行的请自备金山词霸

  7.SQL_TRACE/TKPROF,这个是调整的极佳工具,特别是调整不是自己写的程序,他可以对任何你认为可以的会话进行跟踪,捕获会话的SQL语句,查询计划,CPU使用,消耗时间,一致性读次数,具体的等待事件等,这些信息是极有价值的,想充分利用的话最好能读懂原始的trace文件,而不是通过tkprof翻译的

  8.statspack,这是一个很好数据库调整工具,他采集数据库的系统信息,生成快照,通过对比两个快照之间的差异生成报表,反映系统在这段时间内的运作情况,包括磁盘IO,CPU,内存,锁定,等待事件,buffer gets最大的10条SQL,执行次数最多的SQL,表空间,数据文件IO分布等等等等,在调整时,如果实在没办法找出问题了我会使用他,他也是个很好的系统信息采集工具

  9.UNIX虚拟分页的运作机制,及些乱七八糟的OS性能调整的工具,这部分学的很差,很无味,不知道为什么。
 

【编辑推荐】

  1. Oracle性能调整的误区
  2. 想提高Oracle性能,如何优化数据库?
  3. Oracle性能优化五大工具介绍
  4. Oracle性能的优化技巧的经验总结

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

(0)
运维的头像运维
上一篇2025-05-09 16:25
下一篇 2025-05-09 16:27

相关推荐

  • 个人主题怎么制作?

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

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

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

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

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

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

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

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

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

    2025-11-20
    0

发表回复

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