Oracle HA 之 SERVICE和DRM实战
第一部分:service实战
--oracle 11gR2中创建service的方法:db console和srvctl两种方法。
--db console创建service方法-略
--srvctl创建service方法
[oracle@node1 admin]$ srvctl add service -d dbking -s dbkt02 -r dbking1,dbking2
[oracle@node1 admin]$ srvctl start service -d dbking -s dbkt02
--查看数据库的所有service信息:
[oracle@node1 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:
[oracle@node1 admin]$
[oracle@node1 admin]$ srvctl config service -d dbking -s dbt01
--启动start、关闭stop、修改modify service
启动服务:[oracle@node1 admin]$ srvctl start service -d dbking -s dbkt02
关闭服务:[oracle@node1 admin]$ srvctl stop service -d dbking -s dbkt02
[oracle@node1 admin]$ srvctl stop service -d dbking -s dbkt02 -n node1
[oracle@node1 admin]$ srvctl stop service -d dbking -s dbkt02 -i dbking2
修改服务属性:[oracle@node1 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实战
--准备工作
[oracle@node1 ~]$ srvctl add service -d dbking -s dbkapp -r dbking1,dbking2
[oracle@node1 ~]$ srvctl add service -d dbking -s dbkboss -r dbking1,dbking2
[oracle@node1 ~]$ srvctl start service -d dbking -s dbkboss
[oracle@node1 ~]$ 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;
Oracle HA 之 SERVICE和DRM实战的更多相关文章
- Oracle HA 之 RAC one node实战
--创建rac one node步骤 安装grid软件,配置grid集群:安装oracle软件:dbca创建rac one node. >试验创建的rac one node数据库信息如下: gl ...
- oracle HA 高可用性具体解释(之中的一个)
oracle HA 高可用性具体解释(之二,深入解析TAF,以及HA框架) :http://blog.csdn.net/panfelix/article/details/38436197 一.HA F ...
- oracle HA 高可用性具体解释(之二,深入解析TAF,以及HA框架)
oracle HA 高可用性具体解释(之中的一个,client.server端服务具体解释):http://write.blog.csdn.net/postedit 我们已经看到TAF是的Oracle ...
- OCP培训 Oracle 12c/18c/19c OCP认证实战培训【送OCP优惠名额】
一.OCP培训 Oracle 12c/18c/19c OCP认证全套实战培训[送OCP优惠名额],本课程内容 课程目标: 为满足想参加Oracle OCP考证的学员,风哥设计的一套比较全面OCP实战培 ...
- Oracle HA 之 Server Pool 实战
--创建server pool的两种方式: 图形界面:console和dbca 演示-略 命令行工具:srvctl和crsctl --srvctl和crsctl创建server ...
- Oracle 10g RAC中的DRM问题及关闭
在RAC环境中,Oracle使用GRD(Global Resource Service)来记录各个RAC节点的资源信息,具体通过GCS(Global Cache Service)和GES(Global ...
- java连接oracle数据库使用SERVICE NAME、SID以及TNSName不同写法
格式一: 使用ServiceName方式: jdbc:oracle:thin:@//<host>:<port>/<service_name> 例 jdbc:orac ...
- Oracle HA 之 基于活动数据库复制配置oracle 11.2 dataguard
规划:主库:db_name=dbking db_unique_name=dbkingpri 备库:db_name=dbking ...
- Oracle HA 之 oracle 11.2 rac库配置active dataguard
目录 configing active dataguard for 11.2 rac. 1 一.建组.建用户.配置环境变量.内核参数等... 1 二.配置共享磁盘... 3 1)创建4块共享磁盘并fd ...
随机推荐
- 使用ffmpeg获取视频流后如何封装存储成mp4文件
int main(int argc,char *argv[]) 02 { 03 AVFormatContext *pFormatCtx; 04 int i,videoStream; 05 AVC ...
- Stream(流)的基本操作
//把流转化为文件 public static void StreamToFile(Stream stream, string filepath) { byte[ ...
- 第五章 面向方面编程___OOP和AOP随想
面向方面编程,又称面向切面编程(Aspect-Oriented-Programming),英文缩写 AOP,可以说是 OOP(Object-Oriented-Programming)面向对象编程的补充 ...
- mybatis由浅入深day01_8输出映射_8.1resultType输出类型(8.1.1输出简单类型_8.1.2输出pojo对象和pojo列表_8.1.3输出hashmap)
8 输出映射 8.1 resultType(输出类型) 使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功. 如果查询出来的列名和pojo中的属性名全 ...
- 九度 1537:买卖股票(区间DP)
总结 1. 更新动规矩阵时, 不要 push 更新, 要用 pull更新. push 更新容易让逻辑出问题, 自己卡了很久, 改用 pull 就变得很顺利了 2. acm 题, 空间至多是百万, 再网 ...
- 进程 vs. 线程(python的协程)(转廖雪峰老师python教程)
我们介绍了多进程和多线程,这是实现多任务最常用的两种方式.现在,我们来讨论一下这两种方式的优缺点. 首先,要实现多任务,通常我们会设计Master-Worker模式,Master负责分配任务,Work ...
- HTTP 基础术语
URI 和 URL:URI用于标记一个网络资源,URL则表示这个网络资源的访问地址,详细说明 超文本:普通的一段文字叫做文本,如果给这段文字加上超链接,那么就叫做超文本,HTML 就是超文本标记语言 ...
- cocos2d-x游戏引擎核心之十二——3.x新特性
v3.0 亮点 使用 C++(C++11) 的特性取代了 Objective-C 的特性 优化了 Labels 优化了渲染器(比 v2.2 更快) 新的事件分发机制 物理引擎集成 新的 UI 对象 J ...
- 阿里大于短信返回XML
返回异常和成功的两种不同,XML返回直接拿alibaba_aliqin_fc_sms_num_send_response判断节点是否有这个名字 官方API地址: https://api.alidayu ...
- 【TP3.2】 动态切换数据库方法
1 config 配置: 'connection' => 'mysql://root:root@localhost:3306/dbname', connection 数据库连接字符串,后面代码 ...