牛骨文教育服务平台(让学习变的简单)
博文笔记

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

创建时间:2016-05-25 投稿人: 浏览次数:1255
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://toadworld.com/Portals/0/GuyH/Articles/Oracle%20Parallel%20SQL%20Part%201.pdf
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。