Oracle Study 案例--数据库资源管理器(Oracle Database Resource Manager)

本文涉及的产品
云原生数据仓库AnalyticDB MySQL版,基础版 8ACU 100GB 1个月
简介:

Resource Manager 提供了一种优化数据库资源分配的有效办法,相对于在OS层面进行资源分配,Resource Manager 拥有更精细的控制粒度,以及更小的资源消耗,并且解决了一些OS层面无法解决的资源分配问题。

一,基本概念
. Simple View Of Resource Plan 



Resource consumer group (资源用户组)
A group of sessions that are grouped together based on resource requirements. The Resource Manager allocates resources to resource consumer groups, not to individual sessions.
资源管理器将资源统一分配给资源用户组,而不是某一个具体的会话,当会话建立时会根据自身属性映射到不同的用户组,并从中申请系统资源
. Resource plan (资源计划)
A container for directives that specify how resources are allocated to resource consumer groups. You specify how the database allocates resources by activating a specific resource plan.
一个数据库可以有多个Resource Plan,但是同一时刻只能有一个Plan状态为Active(由初始化参数 resource_manager_plan 决定),关联多个 Resource Plan directive 
. Resource plan directive (资源计划指令)
Associates a resource consumer group with a particular plan and specifies how resources are to be allocated to that resource consumer group.
创建一个计划指令后就决定了系统资源如何分配给一个资源用户组
二,如何创建一个资源计划
1. 
Create Pending Area
All changes to the plan schema must be done within a pending area. The pending area can be thought of as a "scratch" area for plan schema changes.
所有关于 Resource Manager 组件创建和更改都必须在 Pending Area 中完成,文档说可以理解为一个“草稿区” 

  1. SQL> exec DBMS_RESOURCE_MANAGER.CREATE_PENDING_AREA


  2. PL/SQL procedure successfully completed.

2. Create A Resource Planing
创建资源计划时需要注意的一点是如果 sub_plan 参数指定为 TRUE,那么这个计划只能作为子计划使用,并且不需要为 OTHER_GROUPS 创建 Plan Directive

1
2
3
4
5
6
7
8
SQL> BEGIN
   2  DBMS_RESOURCE_MANAGER.CREATE_PLAN(
   3  plan =>  'PLAN1' ,
   4  comment =>  'Test Plan...' ,
   5  sub_plan => FALSE);                   --默认值即为 FALSE
   6  END;
   7  /
PL/SQL procedure successfully completed.
3. Create Consumer Groups
根据实际需求创建所需要的用户组,需要注意的是虽然这一步并没有创建  OTHER_GROUPS  用户组,但是后面必须为 OTHER_GROUPS 用户组创建相对应的 Plan Directive
  1. 1
    2
    3
    4
    5
    6
    7
    8
    SQL> BEGIN
       2  DBMS_RESOURCE_MANAGER.CREATE_CONSUMER_GROUP(
       3  consumer_group =>  'GROUP_OLTP' ,
       4  comment =>  'Group of OLTP USERS...' ,
       5  mgmt_mth =>  'ROUND-ROBIN' );            --该用户组内各会话的CPU资源采取轮询的分配方法
       6  END;
       7  /
    PL/SQL procedure successfully completed.
1
2
3
4
5
6
7
8
SQL> BEGIN
   2  DBMS_RESOURCE_MANAGER.CREATE_CONSUMER_GROUP(
   3  consumer_group =>  'GROUP_OLAP' ,
   4  comment =>  'Group of OLAP USERS...' ,
   5  mgmt_mth =>  'ROUND-ROBIN' );
   6  END;
   7  /
PL/SQL procedure successfully completed.
4. Map Sessions To Consumer Groups
根据会话的登录和运行属性建立该会话和资源用户组的映射关系,可以使用过程 SET_INITIAL_CONSUMER_GROUP 通过“Username”设置用户的初始用户资源组,该过程在11gR1被弃用后,改为使用过程 SET_CONSUMER_GROUP_MAPPING 通过“Session Attribute”来映射用户组,这里所说的会话属性包括: oracle_user,client_os_user,client_program,client_machine,module_name ...
当会话的多个属性映射发生冲突时,会根据每个属性的优先级来决定最终映射关系,使用这个过程来调整属性的优先级:SET_CONSUMER_GROUP_MAPPING_PRI
  1. 1
    2
    3
    4
    5
    6
    7
    8
    SQL> BEGIN
       2  DBMS_RESOURCE_MANAGER.SET_CONSUMER_GROUP_MAPPING(
       3  attribute  =>  'CLIENT_MACHINE' ,
       4  value =>  'ASM' ,                    --将从“ASM”客户机发起的会话映射到“GROUP_OLAP”用户组
       5  consumer_group =>  'GROUP_OLAP' );
       6  END;
       7  /
    PL/SQL procedure successfully completed.
  2. 1
    2
    3
    4
    5
    6
    7
    8
    SQL> BEGIN
       2  DBMS_RESOURCE_MANAGER.SET_CONSUMER_GROUP_MAPPING(
       3  attribute  =>  'CLIENT_MACHINE' ,
       4  value =>  'WORKGROUP\XIAO' ,         --将从“WORKGROUP\XIAO”客户机发起的会话映射到“GROUP_OLTP”用户组
       5  consumer_group =>  'GROUP_OLTP' );
       6  END;
       7  /
    PL/SQL procedure successfully completed.
5. Create Resource Plan Directives
针对会话映射到的每一个用户组创建资源计划指令,可以看做是数据库资源管理的控制核心,这里可以控制的资源种类比较多: CPU 使用、最大活跃会话数、会话并行度、会话最大空闲时间, Undo 使用大小等
  1. SQL> BEGIN

  2.   2 DBMS_RESOURCE_MANAGER.CREATE_PLAN_DIRECTIVE(

  3.   3 plan => 'PLAN1',                                        --将该Plan Directive 关联到 PLAN "Plan1"

  4.   4 group_or_subplan => 'GROUP_OLAP',                       --可以指定用户组,也可以指定Sub Plan,和上一个参数构成了 Plan Diretive 的唯一属性

  5.   5 comment => 'Directives for OLAP consumer group...',

  6.   6 active_sess_pool_p1 => 5,                               --最大活跃会话数,达到该限制后其他会话进入 Inactive session queue

  7.   7 queueing_p1 => 10,                                      --在 Inactive session queue 的等待超时时间

  8.   8 parallel_degree_limit_p1 => 2,                          --最大并行度

  9.   9 switch_group => 'KILL_SESSION',                         --在满足指定条件后,对会话所采取的操作

  10.  10 switch_time => 3,                                       --执行时间限制,会话操作执行时间超过该值后,即被采取上一步的相应操作(second)

  11.  11 switch_estimate => FALSE,                               --如果设置为 TRUE,在操作执行前Oracle先估算执行时间以决定是否对其切换用户组

  12.  12 max_est_exec_time => 5,                                 --最大估算执行时间,优化器对操作时间进行估算,如果超过该值则直接返回“ORA-07455”

  13.  13 undo_pool => NULL,                                      --uncommited undo segments 限制(KB)

  14.  14 max_idle_time => 300,                                   --会话最大空闲时间

  15.  15 max_idle_blocker_time => 3,                             --Blocker会话的最大空闲时间

  16.  16 mgmt_p1 => 30,                                          --CPU使用限制(Level 1)

  17.  17 mgmt_p2 => 0);                                          --CPU使用限制(Level 2)

  18.  18 END;

  19.  19 /

  20. PL/SQL procedure successfully completed.


  21. SQL> BEGIN

  22.   2 DBMS_RESOURCE_MANAGER.CREATE_PLAN_DIRECTIVE(

  23.   3 plan => 'PLAN1',

  24.   4 group_or_subplan => 'GROUP_OLTP',                       --为“GROUP_OLTP”用户组创建指令计划

  25.   5 comment => 'Directives for OLTP consumer group...',

  26.   6 active_sess_pool_p1 => 10,

  27.   7 switch_group => 'CANCEL_SQL',

  28.   8 switch_time => 3,max_idle_time => 3,

  29.   9 mgmt_p1 => 60,

  30.  10 mgmt_p2 => 0);

  31.  11 END;

  32.  12 /

  33. PL/SQL procedure successfully completed.

  34. SQL> BEGIN

  35.   2 DBMS_RESOURCE_MANAGER.CREATE_PLAN_DIRECTIVE(

  36.   3 plan => 'PLAN1',

  37.   4 group_or_subplan => 'OTHER_GROUPS',                     --为没有映射到以上用户组中的会话创建 Plan Directive

  38.   5 comment => 'Directives for the other users group...',

  39.   6 parallel_degree_limit_p1 => 1,

  40.   7 mgmt_p1 => 0,

  41.   8 mgmt_p2 => 100);                                        --CPU使用限制(Level 2 的100%,即 Level 1 分配剩下的10%)

  42.   9 END;

  43.  10 /

  44. PL/SQL procedure successfully completed.

6. Validate & Submit Resource Plan
在对资源管理元素的创建及更改完成后执行校验并提交,如果出现逻辑上的错误会导致报错,比如:
  . 没有定义 OTHER_GROUPS 用户组的 Plan Directive
  . 一个 Plan 中各个 Plan Directive 的 mgmt_p1 或者 mgmt_p2 之和大于 100%
等一些其他的错误
  1. 1
    2
    SQL> exec DBMS_RESOURCE_MANAGER.VALIDATE_PENDING_AREA()
    PL/SQL procedure successfully completed.
  2. 1
    2
    SQL> exec DBMS_RESOURCE_MANAGER.SUBMIT_PENDING_AREA()
    PL/SQL procedure successfully completed.
7. View The Database Resource Manager Elements 
可以通过动态性能视图和数据字典查看,也可以通过EM的图形界面来查看
Consumer Groups:

Consumer Groups Mapping:

Resource Plan Directives:

至此,资源管理计划已经创建完成,修改初始化参数  resource_manager_plan  以启用新的资源管理计划,或者直接在EM控制台中将该计划的状态改为 “Active”
附(动态性能视图及数据字典)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
DBA_RSRC_CATEGORIES
DBA_RSRC_CONSUMER_GROUP_PRIVS
DBA_RSRC_CONSUMER_GROUPS
DBA_RSRC_GROUP_MAPPINGS
DBA_RSRC_IO_CALIBRATE
DBA_RSRC_MANAGER_SYSTEM_PRIVS
DBA_RSRC_MAPPING_PRIORITY
DBA_RSRC_PLAN_DIRECTIVES
DBA_RSRC_PLANS
V$RSRC_CONS_GROUP_HISTORY 
V$RSRC_CONSUMER_GROUP 
V$RSRC_CONSUMER_GROUP_CPU_MTH 
V$RSRC_PLAN 
V$RSRC_PLAN_CPU_MTH 
V$RSRC_PLAN_HISTORY 
V$RSRC_SESSION_INFO 
V$RSRCMGRMETRIC 
V$RSRCMGRMETRIC_HISTORY










本文转自 客居天涯 51CTO博客,原文链接:http://blog.51cto.com/tiany/1605841,如需转载请自行联系原作者
目录
相关文章
|
2天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
29 11
|
3天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
13天前
|
SQL 数据库
gbase 8a 数据库 SQL优化案例-关联顺序优化
gbase 8a 数据库 SQL优化案例-关联顺序优化
|
15天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
21天前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
8天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
1月前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
45 7
|
1月前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
27 5
|
1月前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
58 2
|
7天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。

推荐镜像

更多