ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle 中并行度的设置需要考虑的因素

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

原创 Linux操作系统 作者:pingley 时间:2012-06-12 23:30:45 0 删除 编辑
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 的绝佳材料:

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26110315/viewspace-732619/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 关于Parallel query
请登录后发表评论 登录
全部评论

注册时间:2012-02-06

  • 博文量
    169
  • 访问量
    715781