SERVICE和DRM实战

第一部分:service实战

--oracle 11gR2中创建service的方法:db console和srvctl两种方法。

--db console创建service方法-略

--srvctl创建service方法

[[email protected] admin]$ srvctl add service -d dbking -s dbkt02 -r dbking1,dbking2
[[email protected] admin]$ srvctl start service -d dbking -s dbkt02

--查看数据库的所有service信息:

[[email protected] admin]$ srvctl config service -d dbking
Service name: dbkt01
Service is enabled
Server pool: dbking_dbkt01
Cardinality: 2
Disconnect: false
Service role: PRIMARY
Management policy: AUTOMATIC
DTP transaction: false
AQ HA notifications: false
Failover type: NONE
Failover method: NONE
TAF failover retries: 0
TAF failover delay: 0
Connection Load Balancing Goal: LONG
Runtime Load Balancing Goal: NONE
TAF policy specification: NONE
Edition:
Preferred instances: dbking1,dbking2
Available instances:
Service name: dbkt02
Service is enabled
Server pool: dbking_dbkt02
Cardinality: 2
Disconnect: false
Service role: PRIMARY
Management policy: AUTOMATIC
DTP transaction: false
AQ HA notifications: false
Failover type: NONE
Failover method: NONE
TAF failover retries: 0
TAF failover delay: 0
Connection Load Balancing Goal: LONG
Runtime Load Balancing Goal: NONE
TAF policy specification: NONE
Edition:
Preferred instances: dbking1,dbking2
Available instances:
[[email protected] admin]$

[[email protected] admin]$ srvctl config service -d dbking -s dbt01

--启动start、关闭stop、修改modify service

启动服务:[[email protected] admin]$ srvctl start service -d dbking -s dbkt02

关闭服务:[[email protected] admin]$ srvctl stop service -d dbking -s dbkt02
      [[email protected] admin]$ srvctl stop service -d dbking -s dbkt02 -n node1
      [[email protected] admin]$ srvctl stop service -d dbking -s dbkt02 -i dbking2

修改服务属性:[[email protected] admin]$ srvctl modify service -d dbking -s dbkt02 -i dbking1 -n

relocate操作:dba手动将service从可用实例调回首选实例。
srvctl relocate service -d dbname -s srvname [-c fromnode -n tonode | -i frominstance -t toinstance] [-f]

##########################################################################################################################################

第二部分:DRM实战

--准备工作

[[email protected] ~]$ srvctl add service -d dbking -s dbkapp -r dbking1,dbking2
[[email protected] ~]$ srvctl add service -d dbking -s dbkboss -r dbking1,dbking2
[[email protected] ~]$ srvctl start service -d dbking -s dbkboss                  
[[email protected] ~]$ srvctl start service -d dbking -s dbkapp

SQL> show parameter resource_limit

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
resource_limit                       boolean     FALSE

SQL> show parameter resource_manager_plan

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
resource_manager_plan                string

--命令行方式实现DRM,图形界面方式-略

1)创建一个工作区

SQL> exec dbms_resource_manager.create_pending_area();

PL/SQL 过程已成功完成。

2)创建2个使用者组

SQL> exec dbms_resource_manager.create_consumer_group(consumer_group=>‘app_group‘,comment=>‘普通使用者‘);

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager.create_consumer_group(consumer_group=>‘boss_group‘,comment=>‘boss团‘);

PL/SQL 过程已成功完成。

3)创建消费计划

SQL> exec dbms_resource_manager.create_plan(plan=>‘srv_drm_test01‘,comment=>‘访问资源计划‘);

PL/SQL 过程已成功完成。

4)创建计划细节

SQL> exec dbms_resource_manager.create_plan_directive(plan=>‘srv_drm_test01‘,group_or_subplan=>‘boss_group‘,mgmt_p1=>50,comment=>‘1‘);

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager.create_plan_directive(plan=>‘srv_drm_test01‘,group_or_subplan=>‘app_group‘,mgmt_p1=>20,comment=>‘2‘);

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager.create_plan_directive(plan=>‘srv_drm_test01‘,group_or_subplan=>‘other_groups‘,mgmt_p1=>5,comment=>‘3‘);

PL/SQL 过程已成功完成。

5)创建服务和使用者之间的映射关系

SQL> exec dbms_resource_manager.set_consumer_group_mapping(attribute=>dbms_resource_manager.service_name,value=>‘dbkapp‘,consumer_group=>‘app_group‘);

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager.set_consumer_group_mapping(attribute=>dbms_resource_manager.service_name,value=>‘dbkboss‘,consumer_group=>‘boss_group‘);

PL/SQL 过程已成功完成。

6)校验工作区

SQL> exec dbms_resource_manager.validate_pending_area();

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager.submit_pending_area();

PL/SQL 过程已成功完成。

7)给某个用户赋予能切换到消费组的权限:

SQL> exec dbms_resource_manager_privs.grant_switch_consumer_group(‘SCOTT‘,‘app_group‘,false);

PL/SQL 过程已成功完成。

SQL> exec dbms_resource_manager_privs.grant_switch_consumer_group(‘SCOTT‘,‘boss_group‘,false);

PL/SQL 过程已成功完成。

**授予所有用户可以使用public

8)启动消费计划

SQL> alter system set resource_manager_plan=‘srv_drm_test01‘ scope=both sid=‘*‘;

系统已更改。

9)启动资源限制

SQL> alter system set resource_limit=true scope=both sid=‘*‘;

系统已更改。

******包装一下以上的代码既可以写成脚本*******

--验证生效与否:客户端分别以scott身份登录,通过以下脚本验证。

SQL> select inst_id,username,resource_consumer_group,service_name from gv$session where username=‘SCOTT‘;

INST_ID USERNAME        RESOURCE_CONSUMER_GROUP          SERVICE_NAME
---------- --------------- -------------------------------- ---------------
         1 SCOTT           BOSS_GROUP                       dbkboss
         1 SCOTT           APP_GROUP                        dbkapp

10)检查参数是否生效

SQL> show parameter resource_manager_plan

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
resource_manager_plan                string      test
SQL> show parameter resource_limit

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
resource_limit                       boolean     TRUE

--测试DRM是否生效

1)编写测试脚本:cpu密集型脚本

>PL/SQL脚本如下:

begin
  declare
    m number;
  begin
    for i in 1 .. 1000000 loop
      for j in 1 .. 1000000 loop
        m := sqrt(4567);
      end loop;
    end loop;
  end;
  /

>shell脚本如下:

#!/bin/bash
source /home/oracle/.bash_profile
step=1
while [ $step -lt 6 ]
do
nohup sqlplus scott/oracle @test.sql &
let "step+=1"
echo $step
done

2)检查生效的资源计划是否在管理cpu:

SQL> select name,cpu_managed from v$rsrc_plan where is_top_plan=‘TRUE‘;

NAME                             CPU
-------------------------------- ---
TEST                             ON

3)检查资源计划是如何定义的:

SQL> select group_or_subplan,max_utilization_limit,mgmt_p1 from dba_rsrc_plan_directives where plan=(select name from v$rsrc_plan where is_top_plan=‘TRUE‘);

GROUP_OR_SUBPLAN               MAX_UTILIZATION_LIMIT    MGMT_P1
------------------------------ --------------------- ----------
BOSS_GROUP                                                   50
APP_GROUP                                                    20
OTHER_GROUPS                                                  5

4)登录两个实例分别查询执行结果:

select to_char(m.begin_time, ‘hh:mi‘) time,
       m.consumer_group_name,
       trunc(m.cpu_consumed_time / 60000, 2) avg_runing_sessions,
       trunc(m.cpu_wait_time / 60000, 2) avg_wait_sessions,
       d.mgmt_p1 * (select value from v$parameter where name = ‘cpu_count‘) / 100 allocation
  from v$rsrcmgrmetric_history m, dba_rsrc_plan_directives d, v$rsrc_plan p
where m.consumer_group_name = d.group_or_subplan
   and p.NAME = d.plan
order by m.begin_time, m.consumer_group_name;

时间: 2024-10-17 10:34:03

SERVICE和DRM实战的相关文章

windows中的服务隔离 service isolation and service SID(Virtual Account)

windows 中的服务隔离在windows vista 以及server 2008之后就有了,可以让管理员控制本地资源的使用(如文件.注册表等等).之前windows版本中,系统内置了一些高权限的服务账号,大家所熟悉的有Local System,Network,LocalService 为了最小化权限使用,通常我们需要创建账号来赋予最小权限,然后配置服务以这个账号运行,但是如果服务较多,那么有许许多多的账号要维护,而且如果你有严格的密码策略的话,比如定期要更改服务账号的密码,那真是头疼. wi

实战:percona-xtrabackup 2.1.9 for mysql 5.6.19

----1.编译安装percona-xtrabackup yum install cmake gcc gcc-c++ libaio libaio-devel automake autoconf bzr \ bison libtool ncurses-devel zlib-devel libgcrypt-devel wget http://www.percona.com/downloads/XtraBackup/XtraBackup-2.1.9/source/percona-xtrabackup-

C#源码500份

C#源码500份 C Sharp  短信发送平台源代码.rar http://1000eb.com/5c6vASP.NET+AJAX基础示例 视频教程 http://1000eb.com/89jcC# Winform qq弹窗 360弹窗 http://1000eb.com/89jf精华志 C#高级编程(第七版)源码 http://1000eb.com/89k3C#网络应用编程教案及代码.rar http://1000eb.com/89khIPhone远程桌面xp控制+Desktop+Conne

搭建ftp服务器实现文件共享

FTP服务器(File Transfer Protocol Server)是在互联网上提供文件存储和访问服务的计算机,它们依照FTP协议提供服务. FTP(File Transfer Protocol: 文件传输协议)作用: Internet 上用来传送文件的协议. 常见FTP服务器: windows:Serv-U FTP Server Linux:ProFTPD:(Professional FTP daemon)一个Unix平台上或是类Unix平台上(如Linux, FreeBSD等)的FTP

Android软硬整合设计与框架揭秘: HAL&Framework &Native Service &App&HTML5架构设计与实战开发

掌握Android从底层开发到框架整合技术到上层App开发及HTML5的全部技术: 一次彻底的Android架构.思想和实战技术的洗礼: 彻底掌握Andorid HAL.Android Runtime.Android Framework.Android Native Service.Android Binder.Android App.Android Testing.HTML5技术的源泉和精髓等核心技术,不仅仅是技术和代码本身,更重要的是背后的设计思想和商业哲学. 一.课程特色 l  贯通And

Android软硬整合设计与框架揭秘: HAL&Framework &Native Service &App&Browser架构设计与实战开发

在软硬整合领域, Android以其对软件和硬件的高度开放性引领了当今的软硬整合潮流,全世界正在进行一场轰轰烈烈的Android运动,Android以不可思议的速度渗透越来越广的领域,Android智能手机.Android智能电视.Android微波炉.Android平板电脑.Android智能机器人.Android车载系统等越来越多的Android产品涌入人们的工作和生活中,自从Google的[email protected]战略发布以来,更是让世界对Android充满了怦然心动的期待,可以预

微软实战训练营(X)重点班第(1)课:SOA必备知识之ASP.NET Web Service开发实战

微软实战训练营 上海交大(A)实验班.(X)重点班 内部课程资料 链接:http://pan.baidu.com/s/1jGsTjq2 密码:0wmf <微软实战训练营(X)重点班第(1)课:SOA必备知识之ASP.NET Web Service开发实战>微软实战训练营 上海交大(A)实验班.(X)重点班 .(E)英语口语班http://54peixun.com/MSTrainingCamp/index.html 微软实战训练营(X)重点班第(1)课:SOA必备知识之ASP.NET Web S

Python接口测试实战5(下) - RESTful、Web Service及Mock Server

如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战2 - 使用Python发送请求 Python接口测试实战3(上)- Python操作数据库 Python接口测试实战3(下)- unittest测试框架 Python接口测试实战4(上) - 接口测试框架实战 Python接口测试实战4(下) - 框架完善:用例基类,用例标签,重新运行上次失败用例

【springmvc+mybatis项目实战】杰信商贸-30.出口报运增删查修mapper+Dao+Service+Controller

我们接下来做我们项目的下一个环节,就是出口报运的业务,首先我们来看看两个设计方式 a)大型项目设计方式 传统设计方式,基于对象关联,数据量小时,系统无碍:当数据随着系统的使用,线性增长,系统变的越来越慢,到达一定数据量时,性能急剧下降. b)新的设计方式:打断设计 在表中增加一个字段,这个字段用来存储关联表的主键集合:在报运业务中要查询合同下的货物信息.直接通过这个关联字段,利用in子查询直接去查询货物表,这样查询效率提高很多.而且数据量越大,查询效率越高.这种方式,业务关联层级越多,这种设计方