当前位置:  数据库>oracle

Oracle数据库资源管理

    来源: 互联网  发布时间:2017-06-21

    本文导语: 1.了解Resource Manager术语 Resource Manager的3个基本结构:资源使用者组、资源计划(和辅助计划)、资源计划向导。 使用数据库资源管理器可以帮助管理资源 (如 CPU 和还原空间) 在用户会话间的分配方式。继续执行以下步骤可以配...

1.了解Resource Manager术语

Resource Manager的3个基本结构:资源使用者组、资源计划(和辅助计划)、资源计划向导。

使用数据库资源管理器可以帮助管理资源 (如 CPU 和还原空间) 在用户会话间的分配方式。继续执行以下步骤可以配置资源管理器:

  • 使用者组 定义根据资源处理需求将用户会话分组的使用者组。资源计划将资源分配给使用者组。指定一些用户和角色, 他们可以在每个使用者组中开始会话, 或者将他们的会话切换到每个使用者组。
  • 使用者组映射 定义使用者组映射规则, 此规则基于会话属性 (例如用户名, 服务名, 模块名等) 将用户会话映射到使用者组。要解决映射冲突, 请按映射规则优先级的顺序应用映射规则。
  • 计划 定义资源计划, 其中包含指定将资源分配给使用者组方式的指令。例如, 对于每个计划, 需要指定分配给每个使用者组的 CPU 资源百分比。可以选择指定其他限制, 如使用者组中的会话可以执行或保持空闲的最大时间, 或者会话在自动切换到低优先级的使用者组之前消耗的 CPU 或 I/O 资源的最大量。
  • 设置 查看当前活动的资源计划。激活资源计划。
  • 性能统计信息 监视当前启用的资源计划的统计信息。按使用者组监视 CPU 和 I/O 的使用情况, 并按使用者组监视资源管理器为 CPU 执行的约束数。
2.了解Resource Manager分配方法

Resource Manager可以根据以下一个或多个度量单位分配资源:

  • CPU使用率
  • 并行程度
  • 活动会话数量
  • 撤销空间
  • CPU时限
  • 闲置时间限制
3.了解DEFAULT_PLAN

资源计划resource_manager_plan参数:

SQL> show parameter resource

NAME                                 TYPE                              VALUE
------------------------------------ --------------------------------- ------------------------------
resource_limit                       boolean                           FALSE
resource_manager_cpu_allocation      integer                           2
resource_manager_plan                string
--设置resource_manager_plan为DEFAULT_PLAN
SQL> alter system set resource_manager_plan = 'DEFAULT_PLAN';

System altered.

SQL> show parameter resource

NAME                                 TYPE                              VALUE
------------------------------------ --------------------------------- ------------------------------
resource_limit                       boolean                           FALSE
resource_manager_cpu_allocation      integer                           2
resource_manager_plan                string                            DEFAULT_PLAN

如果未设置resource_manager_plan参数的值,则不在实例中执行资源管理。

4.新建资源计划

可以使用PL/SQL包“DBMS_RESOURCE_MANAGER”的CREATE_PLAN、UPDATE_PLAN和DELETE_PLAN来创建、更新和删除资源计划。

 

--为资源管理器会话创建等待区(必须要创建)
exec DBMS_RESOURCE_MANAGER.CREATE_PENDING_AREA();

--新建资源计划,名称DEVELOPERS
execute DBMS_RESOURCE_MANAGER.CREATE_PLAN -
(Plan => 'DEVELOPERS', -
Comment => 'Developers, in Development database');
5.创建使用者组

新建两个使用者组:ONLINE_DEVELOPERS和BATCH_DEVELOPERS

--新建使用者组 ONLINE_DEVELOPERS
exec DBMS_RESOURCE_MANAGER.CREATE_CONSUMER_GROUP -
(Consumer_Group => 'ONLINE_DEVELOPERS', -
Comment => 'Online developers');

--新建使用者组 BATCH_DEVELOPERS
exec DBMS_RESOURCE_MANAGER.CREATE_CONSUMER_GROUP -
(Consumer_Group => 'BATCH_DEVELOPERS', -
Comment => 'Batch developers');
6.了解资源分配方法

创建两个计划指导,以便将75%的CPU资源分配给ONLINE_DEVELOPERS组,25%的CPU资源分配给BATCH_DEVELOPERS组。
另外,将ONLINE_DEVELOPERS组并行性限制为12,将BATCH_DEVELOPERS组的并行性限制为6。

--ONLINE_DEVELOPERS
exec dbms_resource_manager.create_plan_directive -
(Plan => 'DEVELOPERS', -
Group_or_subplan => 'ONLINE_DEVELOPERS', -
Comment => 'Online developers', -
Cpu_p1 => 75, -
Cpu_p2 => 0, -
Parallel_degree_limit_p1 => 12);

--BATCH_DEVELOPERS
exec dbms_resource_manager.create_plan_directive -
(Plan => 'DEVELOPERS', -
Group_or_subplan => 'BATCH_DEVELOPERS', -
Comment => 'Batch developers', -
Cpu_p1 => 25, -
Cpu_p2 => 0, -
Parallel_degree_limit_p1 => 6);

--OTHER_GROUPS(计划中必须包含此组)
exec dbms_resource_manager.create_plan_directive -
(Plan => 'DEVELOPERS', -
Group_or_subplan => 'OTHER_GROUPS', -
Comment => 'Everyone else', -
Cpu_p1 => 0, -
Cpu_p2 => 100, -
Parallel_degree_limit_p1 => 6);

--验证是否有效
exec DBMS_RESOURCE_MANAGER.VALIDATE_PENDING_AREA();
--提交更改
exec DBMS_RESOURCE_MANAGER.SUBMIT_PENDING_AREA();
--清除更改
exec DBMS_RESOURCE_MANAGER.CLEAR_PENDING_AREA();
7.分配使用者组

将用户合理分配到使用者组中,
将JINGYU分配到Online_developers使用者组:

--赋予JINGYU切换到ONLINE_DEVELOPERS使用者组的权限
exec dbms_resource_manager_privs.grant_switch_consumer_group -
(grantee_name=>'jingyu', -
consumer_group=>'ONLINE_DEVELOPERS', -
grant_option=>true);

--将JINGYU分配到Online_developers使用者组
exec DBMS_RESOURCE_MANAGER.SET_INITIAL_CONSUMER_GROUP -
('JINGYU','ONLINE_DEVELOPERS');

将ALFRED分配到Batch_developers使用者组:

--赋予ALFRED切换到BATCH_DEVELOPERS使用者组的权限
exec dbms_resource_manager_privs.grant_switch_consumer_group -
(grantee_name=>'alfred', -
consumer_group=>'BATCH_DEVELOPERS', -
grant_option=>true);

--赋予用户administer_resource_manager权限
begin
  dbms_resource_manager_privs.grant_system_privilege(
  grantee_name=>'alfred',
  privilege_name=>'administer_resource_manager',
  admin_option=>true);
end;
/

--将alfred分配到Batch_developers使用者组
exec DBMS_RESOURCE_MANAGER.SET_INITIAL_CONSUMER_GROUP -
('alfred','BATCH_DEVELOPERS');
8.激活资源计划
--激活资源计划 DEVELOPERS
alter system set resource_manager_plan = 'DEVELOPERS';
9.了解Resource Manager视图
DBA_RSRC_PLANS                  -> 资源计划和每个计划的状态
DBA_RSRC_PLAN_DIRECTIVES        -> 资源计划指导
DBA_RSRC_CONSUMER_GROUPS        -> 资源计划使用者组
DBA_RSRC_CONSUMER_GROUP_PRIVS   -> 使用者组用户和角色分配
DBA_RSRC_GROUP_MAPPINGS         -> 会话属性与使用者组之间的使用者组映射
DBA_RSRC_MAPPING_PRIORITY       -> 资源映射优先级
DBA_USERS                       -> INITIAL_RSRC_CONSUMER_GROUP列包含用户的初始化使用者
DBA_RSRC_MANAGER_SYSTEM_PRIVS   -> 被授予DBMS_RESOURCE_MANAGER包上的权限的用户

查看每个计划的状态和特点:

set linesize 120
col plan for a30
col status for a30
select plan, status, num_plan_directives, mandatory from dba_rsrc_plans;

status列值为PENDING说明计划尚未经过验证并成功提交;
mandatory列值为YES说明无法删除计划。
10.监视Resource Manager

下面3个动态性能视图显示Resource Manager的统计信息:

v$rsrc_consumer_group   -> 按使用者组列出的CPU使用率
v$sysstat               -> 所有会话的CPU使用率
v$sesstat               -> 按会话列出的CPU使用率

还可以通过EM的Resource Manager下statistics连接查询CPU、I/O、等待时间和排队会话的明细。


    
 
 

您可能感兴趣的文章:

  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 关于JDBC连接Oracle数据库,是否必须有Oracle客户端
  • ORACLE数据库常用字段数据类型介绍
  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)
  • Oracle发布Oracle SQL Developer 1.2数据库开发工具 帮助用户简化开发工作
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • Oracle收购TimesTen 提高数据库软件性能
  • 卸载oracle数据库
  • Oracle数据库恢复后心得
  • linux上安装oracle 数据库后,是否能写shell程序实现数据库的自动启动。
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • Oracle数据库运行Oracle form时避免出现提示信息
  • Oracle欲收购开源数据库MySQL未果
  • 如何在JBuilder中连接Oracle数据库?
  • Oracle数据库访问参数文件的顺序
  • 循序渐进学习Oracle数据库
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • jsp文件上传smartupload到oracle数据库中没有longblob的数据类型如何处理的?
  • 将Oracle 8i数据成功移植Oracle 10g的方法
  • 我从JSP页将数据插入到oracle数据库中,为何汉字插入后数据库中显示为乱码呢?
  • 紧急求救:对Oracle数据库中long 型数据进行模糊查询 如何查?
  • Linux下Oracle数据库,dbstart持续不动,数据库无法启动解决
  • 紧急求救:jsp对Oracle数据库中long 型数据进行模糊查询 如何查?
  • 请问:ORACLE中的数据取出来后,需不需要进行一定的转换才能变为C语言的数据类型啊?
  • 手把手教你Oracle数据库导出数据库结构到PowerDesigner
  • Oracle与FoxPro两数据库的数据转换步骤
  • Oracle 对数据文件大小的限制
  • 数据库服务器 Oracle
  • 关于系统重装后Oracle数据库完全恢复的解决办法
  • 取数据库前几条数据(sql server、oracle、mysql)的sql写法
  • oracle数据库入门知识简述
  • linux下用什么办法连接oracle数据库并且读取数据呢?(用c++代码实现时)
  • 深入理解Oracle数据库的启动和关闭
  • 轻松理解Oracle数据库中的物理结构
  • 用java怎样实现oracle数据库表和excel数据表的转换
  • 高手相送,jsp连接oracle数据库后,显示数据为乱码?
  • jbuilder6 中怎样引入oracle 数据访问包
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • ORACLE日期相关操作
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!


  • 站内导航:


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

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3