• Oracle Parallel 多线程


    对于一个大的任务,一般的做法是利用一个进程,串行的执行,如果系统资源足够,可以采用parallel技术,把一个大的任务分成若干个小的任务,同时启用n个进程/线程,并行的处理这些小的任务,这些并发的进程称为并行执行服务器(parallel executeion server),这些并发进程由一个称为并发协调进程的进程来管理。

    启用Parallel前的忠告:只有在需要处理一个很大的任务,如需要几十分钟,几个小时的作业中,并且要有足够的系统资源的情况下(这些资源包括cpu,内存,io),您才应该考虑使用parallel。否则,在一个多并发用户下,系统本身资源负担已经很大的情况下,启用parallel,将会导致某一个会话试图占用了所有的资源,其他会话不得不去等待,从而导致系统系能反而下降的情况,一般情况下,oltp系统不要使用parallel,oltp系统中可以考虑去使用。

    Parallel分类

    l  并行查询parallel query

    l  并行dml parallel dml pdml

    l  并行ddl parallel ddl pddl

    一、 并行查询

    并行查询允许将一个sql select语句划分为多个较小的查询,每个部分的查询并发地运行,然后将各个部分的结果组合起来,提供最终的结果,多用于全表扫描,索引全扫描等,大表的扫描和连接、创建大的索引、分区索引扫描、大批量插入更新和删除

    1.    启用并行查询

    SQL> ALTER TABLE T1 PARALLEL;

    告知oracle,对T1启用parallel查询,但并行度要参照系统的资源负载状况来确定。

    利用hints提示,启用并行,同时也可以告知明确的并行度,否则oracle自行决定启用的并行度,这些提示只对该sql语句有效。

    SQL> select /*+ parallel(t1 8) */ count(*)from t1;

    SQL> select degree from user_tables where table_name='T1';

    DEGREE

    --------------------

      DEFAULT

    并行度为Default,其值由下面2个参数决定

    SQL> show parameter cpu

    NAME                                TYPE       VALUE

    ----------------------------------------------- ------------------------------

    cpu_count                           integer    2

    parallel_threads_per_cpu            integer    2

    cpu_count表示cpu数

    parallel_threads_per_cpu表示每个cpu允许的并行进程数

    default情况下,并行数为cpu_count*parallel_threads_per_cpu

    2.    取消并行设置

    SQL> alter table t1 noparallel;

    SQL> select degree from user_tables wheretable_name='T1';

    DEGREE

    ----------------------------------------

            1

    3.    数据字典视图

    v$px_session

    sid:各个并行会话的sid

    qcsid:query coordinator sid,查询协调器sid

    二、 并行dml

    并行dml包括insert,update,delete,merge,在pdml期间,oracle可以使用多个并行执行服务器来执行insert,update,delete,merge,多个会话同时执行,同时每个会话(并发进程)都有自己的undo段,都是独立的一个事务,这些事务要么由pdml协调器进程提交,要么都rollback。

    在一个有充足I/o带宽的多cpu主机中,对于大规模的dml,速度可能会有很大的提升,尤其是在大型的数据仓库环境中。

    并行dml需要显示的启用

    SQL> alter session enable parallel dml;

    Disable并行dml

    SQL> alter session disable parallel dml;

    三、 并行ddl

    并行ddl提供了dba使用全部机器资源的能力,常用的pddl有

    create table as select ……

    create index

    alter index rebuild

    alter table move

    alter table split

    在这些sql语句后面加上parallel子句

    SQL> alter table t1 move parallel;

    Table altered

    SQL> create index T1_IDX on T1 (OWNER,OBJECT_TYPE)

     2   tablespace SYSTEM

    3        parallel;

    4        ;

  • 相关阅读:
    元素的ID和Name有什么区别???[转自"天道酬勤"]
    招聘时会问到的问题
    关于asp.net开发B/S应用系统的思索和讨论
    软件文档知多少?
    C# 编码规范和编程好习惯
    [转]多层结构来开发ASP.NET程序
    ASP.NET页面间的传值的几种方法
    为sql server 表数据生成创建的储存过程(生成insert 脚本)
    XHTML+CSS应用教程——利用CSS实现双语导航条
    XHTML+CSS应用教程——CSS实现文字的双影
  • 原文地址:https://www.cnblogs.com/richelle009/p/5509308.html
Copyright © 2020-2023  润新知