当前位置:  数据库>oracle

Oracle 中并行度的设置需要考虑的因素

    来源: 互联网  发布时间:2017-04-29

    本文导语: 并行执行是Oracle 中一项比较重要的技术,特别是在OLAP系统中,应对长期运行资源消耗高的SQL语句。并行度的设置对于使用oracle并行执行特性来说是一项关键而复杂的任务,设置的不恰当,可能反而因为使用oracle 并行执行特性而...

并行执行是Oracle 中一项比较重要的技术,特别是在OLAP系统中,应对长期运行资源消耗高的SQL语句。并行度的设置对于使用oracle并行执行特性来说是一项关键而复杂的任务,设置的不恰当,可能反而因为使用oracle 并行执行特性而导致系统的性能下降。

oracle 中并行度的设置不仅仅是通过几个参数的调整那么简单,更重要的是明确以下几个问题。

1、服务器的CPU核心数。

虽然现在的笔记本电脑都早已经跨入双核的时代,更不用说是服务器了,但是还是可能存在你的服务器运行在单个CPU的虚拟机上面。即使你的服务器有多个核心,但是把并行度设置的过高是不明智的。所有应该认真的考虑一下CPU核心数和并行度的关系。

2、访问的数据在磁盘上面是如何组织的。

如果是存储在单个磁盘上面,因为并行进程或者线程要排队等待访问磁盘,会削弱并行处理的优势,如果要访问的数据按照能够并行访问的方式组织在多个磁盘设备上面(并不是数据组织到多个磁盘就能够并行访问的),那么并行的优势将会很明显。

3、要采用并行执行的SQL是什么性质的。

那些长期运行或者资源密集型的SQL语句,才能够在并行执行中获得益处。

那些短小的SQL语句并不是适合采用并行执行。因为初始化和协调多个并行进程存在一定的开销。所有说事务性的语句不适合采用并行执行,并行执行更多的场合是使用在OLAP系统中。

注:系统中不可能所有的SQL语句都采用并行执行,也没有这个必要。

4、系统的负载。

即使你的系统中CPU核心数很多,IO性能也很好,也支持并行IO,内存也大。

但是系统的负载却可能很高,这时候如果启用较多的并行进程,将会导致系统整体性能的下降,因为并行执行是典型的“以资源换时间”的例子。所有采用并行执行的时候确保系统中的可用资源比较充足。

5、整体也个体的关系。

这里需要注意一点是,并行执行的SQL语句对系统其他SQL语句性能的影响。系统中资源的总量是固定的,貌似采用虚拟化技术可以动态的调整系统中的总体资源。

但是调整需要时间,另外并是不所有的系统都采用了这种技术,更重要的前提是money。所有在系统资源总量不变的情况下,你并行执行的SQL语句消耗的资源多了势必其他SQL执行可用的资源就减少了,从而导致系统中其他SQL语句的执行性能下降。

所以我们需要做一个tradeoff.

6、什么样的SQL语句可以并行的执行。

并不是所有的SQL语句的执行都可以并行执行,如果你不知道SQL语句并行执行的条件,那么很可能导致这一的疑问,我采用了并行执行,怎么性能没有提高?

7、并行执行不是在做SQL优化。

跑出某个结果或者实施某个操作,使用并行执行只是使用更多的资源来换取较短的执行时间,并不是实施SQL的优化。如果采用并行执行的SQL本身有性能问题的话那么并行执行将会放大这一问题,影响其他SQL语句的执行。

8、请先测试。

为了确保并行执行能够满足你的需求,请先进行测试。

对于oracle parallel SQL 的绝佳材料:

免费下载地址在 http://linux.linuxidc.com/

用户名与密码都是www.linuxidc.com

具体下载目录在 /2012年资料/6月/20日/Oracle 中并行度的设置需要考虑的因素


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,