知识大全 优化策略

Posted 数据库

篇首语:恢弘志士之气,不宜妄自菲薄。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 优化策略相关的知识,希望对你有一定的参考价值。

  性能调试的一般问题     Introduction 介绍    本文档包括了最一般的调优策略 关于各部分的更专门的信息可以通过提供的链接得到      Shared Pool and Library Cache Performance Tuning 共享池和Library Cache的调优    Oracle将SQL语句 存储包 对象信息和很多其他的项目保存在SGA中一个叫共享池(shared pool)的地方 这个可共享的区域由一个成熟的高速缓存和堆管理器管理 它有 个基本的问题要克服      ) 内存分配的单元不是个常量 从池中分配的内存单元可能是从几个字节到几千个字节      ) 在用户完成工作时 不是所有的内存都能够释放出来 因为共享池的目标是使信息最大程度的共享      ) 没有一个象其他常规的高速缓存的文件做后备的存储那样磁盘空间供整页的导出     只有可重新创建的信息可以从Cache中丢弃 在他被再次需要的时候再重新创建     共享池调优的技巧有      刷( Flush)共享池可以使小块的内存合并为大块的内存 当共享池的碎片过多时 这能够暂时恢复性能 刷共享池可以使用语句 alter system flush shared_pool;   注意执行这个语句将会造成性能的暂时尖峰 因为对象都要重新加载 所以应当在数据库的负载不是很大的情况下进行      确保联机事务处理( OLTP)应用使用绑定变量 (bind variables) 这一点对于决策支持系统(DSS)并不重要      确保library cache 的命中率 > %     增大共享池并不总能解决命中率过多的问题      Buffer Cache Performance Tuning 数据库缓存调优    数据库缓存保持了从磁盘上读去的数据块的备份     因为缓存通常受到内存约束的限制 不是磁盘上所有的数据都可以放到缓存里 当缓存满了的时候 后来的缓存不中使得Oracle将已经在缓存中的数据写到磁盘上 后续的对写到磁盘上的数据的访问还会造成缓存不中     数据库缓存调优的技巧如下     避免以下的问题     缓存的最近最少使用(LRN)链 ( cache buffers LRU chain )的加锁竞争     平均写队列 ( Average Write Queue )长度过大     过多时间花在等待 写完毕等待上 ( write plete waits )     过多时间花在等待 缓冲释放等待 上 ( free buffer waits )     Latch Contention 加锁(插销)竞争     插销加锁是SGA中保护共享数据结构的低层的串行化机制 插销latch是一类可以非常快的获得和释放的锁 插销锁的实现是依赖于操作系统的 尤其在关于一个进程是否会等待一个锁 和等多久方面     有如下的锁(插销)需要调优:      Redo Copy/Allocation Latch 重写日志的复制/分配插销     Shared Pool Latch 共享池的插销     Library Cache Latch Library Cache插销          Redo Log Buffer Performance Tuning 重写日志缓冲的调优     LGWR 将重写日志缓冲中的重写项写到重写日志文件中     一旦LGWR将这些项复制到重写日志文件中 用户进程就可以重写这些项 统计项目 redo log space requests 反映了用户进程等待重写日志缓冲中空间的时间的数字     设置重写日志大小的一些提示:     redo log space requests 的值应该接近      设定合适的重写日志的大小 建议每 分钟进行一次重写日志的切换      Query Performance Tuning 查询效率的调优     如果查询运行得很慢 请考虑这些方面:     你希望这个查询运行的有多快以及有理由这样要求吗?     优化模式OPTIMIZER_MODE 设为何值?     查询涉及的索引都是有效的吗?     在数据库中有没有其他的长时间运行的查询(大查询)    对于CBO(基于成本的优化)In case of CBO:     表和索引上有统计信息吗?     统计信息是被计算出来的还是被估计出来的?    对于查询的性能调整由两个主要的调试工具      TKPROF      AUTOTRACE           Rollback Segment Performance Tuning 回滚段的调优     Oracle数据库提供了任何数据库对象上的SELECT INSERT UPDATE 和DELETE 操作的读一致性 回滚段用于保存由那些要回滚的动作或系统需要产生一个和前面某一时间读一致的影像所产生的可取消事务     设置回滚段大小的技巧如下      建议最少每 个事务一个回滚段     建议为长时间运行的大查询提供一个大回滚段      v$rollstat中的wrap数接近 否则增大扩展大小(extent size)      SELECT b name a wraps FROM V$ROLLSTAT a V$ROLLNAME b;          Temporary Tablespace Performance Tuning 临时表空间的调优     从RDBMS release 开始 Oracle引入了临时表空间的概念 这个表空间用于保存临时对象 如排序段 排序段采用它所在的表空间的缺省存储参数(DEFAULT STORAGE (NEXT) 子句)作为自己的存储参数     临时表空间的调优的技巧如下:     如果即使在稳定的状态下也存在很多的排序扩展锁(Sort Extent Pool latch)的竞争 你应该通过修改临时表空间的DEFAULT STORAGE 子句的NEXT值来增大扩展块的大小      如果存在很多的排序扩展锁(Sort Extent Pool latch)的竞争并且这种等待是由于过多的并发的排序造成的 你应该增大SORT_AREA_SIZE参数的大小 以使更多的排序能保存在内存中      建议让扩展块的大小和SORT_AREA_SIZE参数相同      以此例说明为什么 假设你的 extent size = K 而 sort_area_size = Mg     现在如果有个到磁盘的排序 每次都要做 个 K的扩展 这会导致性能的降低      Utlbstat/Utlestat Performance Tuning Utlbstat/Utlestat调优    Bstat/Estat 是一堆存放在你的$ORACLE_HOME/rdbms/admin目录下的SQL脚本 他们对于捕获系统范围的数据库性能统计的快照非常有用 UTLESTAT 创建这些视图的第二个快照 并将两个快照之间的差异报告到文件 report txt 中     Bstat sql 在你的sys用户下创建一系列的表和视图 其中包括开始时数据库性能统计的快照     Estat sql在你的sys用户下创建一系列的表 其中包括结束时数据库性能统计的快照和一个叫 report txt 的文件     一些技巧:     确保你已经将TIMED_STATSTICS设为TRUE (这仅仅给数据库操作增加了一点非常小的开销)      确保数据库在运行utlbstat前 已经启动并且运行了一段时间      从svrmgrl 中而不是sql*plus中运行utbstat sql和utlestat sql      确保在脚本utlbstat/estat运行时 数据库不被Down掉 否则产生的统计就不正确      至少运行utlbstat/estat 个小时 才好调试你的数据库           Checkpoint Performance Tuning 检查点性能调优    检查点( Checkpoint)是一个数据库事件 用来同步内存和磁盘上的数据文件中的数据块 检查点的目的有两个     ( ) 建立数据的一致性  ( ) 是数据库恢复更快     调优检查点进程有如下的技巧      CKPT进程能够明显的提高效率来降低用户等待一个检查点操作完毕所需的时间      如果LOG_CHECKPOINT_INTERVAL的值比重写日志( redo log)的大小大 那么 checkpoint只在ORACLE进行日志从一个组到另一组切换的时候才发生 这正是我们希望的 这个行为在 Oracle i中有了变化      当把LOG_CHECKPOINTS_TO_ALERT设为TRUE时 将把checkpoint启动和停止的时间记录在alert log日志里 这对于你确定checkpoint是否正以最佳的频率发生很有帮助      理想的情况是 checkpoint在仅在日志切换时发生      Import Performance Tuning 数据载入性能调优     没有什么固定的信息是关于如何加速那些慢得让人难以忍受的import的 显然import要花费它完成所需要的时间 但是作一些事情可以缩短他们所花的时间 cha138/Article/program/Oracle/201311/17655

相关参考

知识大全 Oracle数据库系统性能优化策略

Oracle数据库系统性能优化策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  一个数据库系统

知识大全 Oracle学习应用之数据库性能优化策略

Oracle学习应用之数据库性能优化策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  数据库系

知识大全 了解DB2数据库优化的几条策略

了解DB2数据库优化的几条策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  对后续用到的表建立

知识大全 浅谈优化SQLServer数据库服务器内存配置的策略

浅谈优化SQLServer数据库服务器内存配置的策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 了解有关DB2数据库优化的几条策略

了解有关DB2数据库优化的几条策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  对后续用到的表

知识大全 DB2数据库优化需掌握的几条基本策略

DB2数据库优化需掌握的几条基本策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! &n

知识大全 hibernate的性能优化

  Hibernate是对JDBC的轻量级封装因此在很多情况下Hibernate的性能比直接使用JDBC存取数据库要低然而通过正确的方法和策略在使用Hibernate的时候还是可以非常接近直接使用JD

知识大全 hibernate的优化-懒加载(lazy)

  为了进一步优化Hibernate的性能可以使用  延迟加载技术管理数据抓取策略进行缓存管理等方面考虑来提高Hibernate的性能  延迟加载(load)  延迟加载(load)是Hibernat

集散系统过程管理级的主要功能有哪些?

  集散系统过程管理级的主要功能有:  (1)优化过程控制。根据生产过程的数学模型与现场条件及参数的变化实现优化,针对生产过程的类型和对生产的要求可选用不同的优化指标和优化策略。得出的优化命令或参数可

集散系统过程管理级的主要功能有哪些?

  集散系统过程管理级的主要功能有:  (1)优化过程控制。根据生产过程的数学模型与现场条件及参数的变化实现优化,针对生产过程的类型和对生产的要求可选用不同的优化指标和优化策略。得出的优化命令或参数可