Recently, One customer asked me, can we deploy the ‘resource_manager’ on the standby DB?

As per my test, I get the conclusion:"’Yes, we can!’.

The following are my test steps, they include four parts,

1. Prepare part  --- Create the users, resource plan, consumer group and so on.

2. Check part    --- Verify the validity of the objects, which created on prepare part. 

3. Test part(On Primary DB ) ---Test the RM effect on Primary DB.

4. Test part(On Standby DB ) ---Test the RM effect on Standby DB.

Now, start our test case.

Prepare part

************************************************************

 
  1. 1. Create users:  
  2. create user RUSER identified by ruser;  
  3. grant dba to RUSER; 
  4.  
  5. create user liang identified by liang;  
  6. grant dba to liang; 
  7.  
  8. 2: Create a plan:  
  9. begin  
  10. dbms_resource_manager.create_pending_area();  
  11. end;  
  12.  
  13. begin  
  14. dbms_resource_manager.create_plan( plan => 'TEST_CPU_RES', comment => 'Resource plan/method for CPU resources');  
  15. end;  
  16.  
  17. 3. Create Consumer Groups:  
  18. begin   
  19. dbms_resource_manager.create_consumer_group ( consumer_group => 'NORMAL_Group' , comment =>'ALL normal Users'); dbms_resource_manager.create_consumer_group ( consumer_group => 'STATS_Group', comment => 'Statistic jobs');   
  20. end;   
  21.  
  22. 4. Create plan directives:  
  23. begin   
  24. dbms_resource_manager.create_plan_directive ( plan => 'TEST_CPU_RES', group_or_subplan =>'NORMAL_Group',comment => 'Limit CPU resource', cpu_p1 => 80 );   
  25. dbms_resource_manager.create_plan_directive ( plan => 'TEST_CPU_RES', group_or_subplan => 'STATS_Group',comment => 'Limit CPU resource', cpu_p1 => 20);   
  26. dbms_resource_manager.create_plan_directive ( plan => 'TEST_CPU_RES', group_or_subplan =>'OTHER_GROUPS',comment => 'Limit CPU resource', cpu_p1 => 0 );   
  27. end;   
  28.  
  29. 5. Validate and submit the plan:  
  30. begin  
  31. dbms_resource_manager.validate_pending_area();  
  32. end;  
  33.  
  34. begin  
  35. dbms_resource_manager.submit_pending_area();  
  36. end;  
  37.  
  38. 6. Group switching:  
  39. begin  
  40. dbms_resource_manager_privs.grant_switch_consumer_group(grantee_name=>'RUSER',consumer_group=>'STATS_Group',grant_option=>FALSE); 
  41. dbms_resource_manager_privs.grant_switch_consumer_group(grantee_name=>'LIANG',consumer_group=>'NORMAL_Group',grant_option=>FALSE); 
  42. end;  
  43.  
  44. 7. Assign the user 'RUSER' of the database a default initial consumer group at connection time:  
  45. begin  
  46. dbms_resource_manager.create_pending_area();  
  47. end;  
  48.  
  49. begin  
  50. dbms_resource_manager.set_initial_consumer_group(user => 'RUSER',consumer_group =>'STATS_Group');  
  51. dbms_resource_manager.set_initial_consumer_group(user => 'LIANG',consumer_group =>'NORMAL_Group');  
  52. end;  
  53.  
  54. begin  
  55. dbms_resource_manager.validate_pending_area();  
  56. end;  
  57.  
  58. begin  
  59. dbms_resource_manager.submit_pending_area();  
  60. end;  
  61.   

Check part

************************************************************

 
  1. 1. Check the relationship of the user and the consumer_group 
  2.  
  3. SQL> SELECT * FROM DBA_RSRC_CONSUMER_GROUP_PRIVS where grantee like 'RUSER%'; 
  4.  
  5. GRANTEE                        GRANTED_GROUP                  GRA INI  
  6. ------------------------------ ------------------------------ --- ---  
  7. RUSER                            STATS_GROUP                    NO  YES 
  8.  
  9. SQL> SELECT * FROM DBA_RSRC_CONSUMER_GROUP_PRIVS where grantee like 'LIANG%'; 
  10.  
  11. GRANTEE                        GRANTED_GROUP                  GRA INI  
  12. ------------------------------ ------------------------------ --- ---  
  13. LIANG                          NORMAL_GROUP                   NO  YES 
  14.  
  15. 2. Check the resource plan, what consumer groups are include in this plan: 
  16.  
  17. SQL> SELECT group_or_subplan, mgmt_p1, mgmt_p2, mgmt_p3, mgmt_p4, max_utilization_limit  
  18. FROM dba_rsrc_plan_directives WHERE plan = upper('TEST_CPU_RES');   
  19.  
  20. GROUP_OR_SUBPLAN                  MGMT_P1    MGMT_P2    MGMT_P3    MGMT_P4 MAX_UTILIZATION_LIMIT  
  21. ------------------------------ ---------- ---------- ---------- ---------- ---------------------  
  22. NORMAL_GROUP                           80          0          0          0  
  23. STATS_GROUP                            20          0          0          0  
  24. OTHER_GROUPS                            0          0          0          0 
  25.  
  26. 3. Query the current active plan  
  27. SQL> SELECT NAME, IS_TOP_PLAN FROM V$RSRC_PLAN; 
  28.  
  29. NAME                             IS_TO  
  30. -------------------------------- -----  
  31. INTERNAL_PLAN                    TRUE                               <<<<<Is is not expect plan, which is the default plan 
  32.  
  33. SQL> set line 1000  
  34. SQL> select group_or_subplan, mgmt_p1, mgmt_p2, mgmt_p3, mgmt_p4, mgmt_p5, mgmt_p6, mgmt_p7, mgmt_p8, max_utilization_limit from dba_rsrc_plan_directives  
  35. where plan = (select name from v$rsrc_plan where is_top_plan = 'TRUE');  2 
  36.  
  37. GROUP_OR_SUBPLAN                  MGMT_P1    MGMT_P2    MGMT_P3    MGMT_P4    MGMT_P5    MGMT_P6    MGMT_P7    MGMT_P8 MAX_UTILIZATION_LIMIT  
  38. ------------------------------ ---------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ---------------------  
  39. OTHER_GROUPS                            0          0          0          0          0          0          0          0   <<<<<Only OTHER_GROUPS in the default INTERNAL_PLAN plan 
  40.  
  41. 4.  Take effect for the setting of your resource_manager_plan. 
  42.  
  43. SQL> alter system set resource_manager_plan='plan_test' scope=both
  44.  
  45. SQL> show parameter resource_manager_plan 
  46.  
  47. NAME                                 TYPE        VALUE  
  48. ------------------------------------ ----------- ------------------------------  
  49. resource_manager_plan                string      TEST_CPU_RES                                     <<<<<This plan was created by ourselves 
  50.  
  51. ---The current active plan  
  52. SQL> SELECT NAME, IS_TOP_PLAN FROM V$RSRC_PLAN; 
  53.  
  54. NAME                             IS_TO  
  55. -------------------------------- -----  
  56. TEST_CPU_RES                     TRUE       
  57.  
  58. 5. check current setting of plan 
  59.  
  60. SQL> select group_or_subplan, mgmt_p1, mgmt_p2, mgmt_p3, mgmt_p4, mgmt_p5, mgmt_p6, mgmt_p7, mgmt_p8, max_utilization_limit from dba_rsrc_plan_directives  
  61. where plan = (select name from v$rsrc_plan where is_top_plan = 'TRUE');    
  62.  
  63. GROUP_OR_SUBPLAN                  MGMT_P1    MGMT_P2    MGMT_P3    MGMT_P4    MGMT_P5    MGMT_P6    MGMT_P7    MGMT_P8 MAX_UTILIZATION_LIMIT  
  64. ------------------------------ ---------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ---------------------  
  65. NORMAL_GROUP                           80          0          0          0          0          0          0          0  
  66. STATS_GROUP                            20          0          0          0          0          0          0          0  
  67. OTHER_GROUPS                            0          0          0          0          0          0          0          0 
  68.  
  69.   

Test part----On Primary DB

************************************************************

 
  1. 1.  Executes this script by user liang/RUSER to produce the workload 
  2.  
  3. DECLARE  
  4. n NUMBER;  
  5. BEGIN  
  6. WHILE (TRUE)  
  7. LOOP  
  8. n:dbms_random.random();  
  9. END LOOP;  
  10. END; 
  11.  
  12. 2. The output of the command top  
  13. -----First fetch -----  
  14. top - 04:58:29 up 22 days, 23:24,  6 users,  load average: 1.49, 1.81, 1.19  
  15. Tasks: 323 total,   2 running, 321 sleeping,   0 stopped,   0 zombie  
  16. Cpu(s): 99.0%us,  1.0%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  17. Mem:   3361028k total,  3178564k used,   182464k free,   186904k buffers  
  18. Swap:  2433836k total,   916564k used,  1517272k free,  1136416k cached 
  19.  
  20.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  21. 15308 oracle    20   0  945m  33m  29m R 79.1  1.0   9:22.40 oracle       <<<<<<<<<<<<<<<< user liang  
  22. 15294 oracle    20   0  946m  38m  34m S 15.9  1.2   5:35.10 oracle       <<<<<<<<<<<<<<<< user RUSER  
  23. -----sencond fetch-----  
  24. top - 05:02:21 up 22 days, 23:28,  6 users,  load average: 1.09, 1.40, 1.15  
  25. Tasks: 325 total,   2 running, 323 sleeping,   0 stopped,   0 zombie  
  26. Cpu(s): 99.0%us,  1.0%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  27. Mem:   3361028k total,  3188012k used,   173016k free,   187256k buffers  
  28. Swap:  2433836k total,   916560k used,  1517276k free,  1136912k cached 
  29.  
  30.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  31. 15308 oracle    20   0  945m  33m  29m R 75.1  1.0  12:16.24 oracle      <<<<<<<<<<<<<<<< user liang  
  32. 15294 oracle    20   0  946m  38m  34m S 18.9  1.2   6:19.51 oracle      <<<<<<<<<<<<<<<< user RUSER 
  33.  
  34. 3. Query the current session 
  35.  
  36. SQL> select s.username,s.STATUS,p.SPID  
  37.      from v$session s, v$process p  
  38.      where s.PADDR=p.ADDR and s.username='LIANG' OR s.username='RUSER' order by s.username; 
  39.  
  40. RUSER                            ACTIVE   15294  
  41. LIANG                          ACTIVE   15308 
  42.  
  43. 4. Only executes this script by user liang, the output idicates, if there isn't other process, it can obtain all the CPU resource. 
  44.  
  45. top - 04:45:27 up 22 days, 23:11,  6 users,  load average: 1.20, 0.51, 0.19  
  46. Tasks: 322 total,   2 running, 320 sleeping,   0 stopped,   0 zombie  
  47. Cpu(s): 99.0%us,  1.0%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  48. Mem:   3361028k total,  3171100k used,   189928k free,   185980k buffers  
  49. Swap:  2433836k total,   916580k used,  1517256k free,  1134700k cached 
  50.  
  51.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  52. 15308 oracle    20   0  945m  33m  29m R 94.6  1.0   2:44.50 oracle           <<<<<<<<<<<<<<<< user liang    
  53. 5. Only executes this script by user RUSER, which can obtain all the resource.  
  54. top - 05:03:34 up 22 days, 23:29,  6 users,  load average: 1.02, 1.31, 1.14  
  55. Tasks: 324 total,   2 running, 322 sleeping,   0 stopped,   0 zombie  
  56. Cpu(s): 99.0%us,  1.0%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  57. Mem:   3361028k total,  3185392k used,   175636k free,   187332k buffers  
  58. Swap:  2433836k total,   916560k used,  1517276k free,  1137264k cached 
  59.  
  60.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  61. 15294 oracle    20   0  946m  39m  35m R 94.3  1.2   6:43.45 oracle           <<<<<<<<<<<<<<<< user RUSER  
  62. 6. Executes this script by both liang and RUSER, the CPU resource was allotted as the resource manager plan.(80/20)  
  63. top - 05:04:25 up 22 days, 23:30,  6 users,  load average: 1.09, 1.27, 1.13  
  64. Tasks: 324 total,   2 running, 322 sleeping,   0 stopped,   0 zombie  
  65. Cpu(s): 98.7%us,  1.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  66. Mem:   3361028k total,  3185160k used,   175868k free,   187384k buffers  
  67. Swap:  2433836k total,   916560k used,  1517276k free,  1137368k cached 
  68.  
  69.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  70. 15308 oracle    20   0  945m  33m  30m R 75.1  1.0  13:04.20 oracle  
  71. 15294 oracle    20   0  946m  39m  35m S 18.9  1.2   7:27.63 oracle 

Test part----On Standby DB

************************************************************

 

 
  1. 1. Confirm if the standby DB is sync with the primary DB  
  2. select max(SEQUENCE#),applied from  v$archived_log group by applied; 
  3.  
  4. 2. Query the parameter  
  5. SQL> show parameter resource_manager_plan 
  6.  
  7. NAME                                 TYPE        VALUE  
  8. ------------------------------------ ----------- ------------------------------  
  9. resource_manager_plan                string       
  10.  
  11. 3. Query the current active plan  
  12. SQL> SELECT NAME, IS_TOP_PLAN FROM V$RSRC_PLAN; 
  13.  
  14. NAME                             IS_TO  
  15. -------------------------------- -----  
  16. INTERNAL_PLAN                    TRUE                              <<<<<the current plan is the default. 
  17.  
  18. 4. Manually set the parameter to the expect plan.  
  19. SQL> alter system set resource_manager_plan='TEST_CPU_RES' scope=both;  
  20. SQL> show parameter resource_manager_plan 
  21.  
  22. NAME                                 TYPE        VALUE  
  23. ------------------------------------ ----------- ------------------------------  
  24. resource_manager_plan                string      TEST_CPU_RES 
  25.  
  26. SQL> SELECT NAME, IS_TOP_PLAN FROM V$RSRC_PLAN; 
  27.  
  28. NAME                             IS_TO  
  29. -------------------------------- -----  
  30. TEST_CPU_RES                     TRUE 
  31.  
  32. 5. Executes this script by both liang and RUSER, the CPU resource was allotted as the resource manager plan.(80/20)  
  33. top - 05:28:04 up 7 days, 17:34,  4 users,  load average: 0.79, 0.27, 0.09  
  34. Tasks: 211 total,   2 running, 209 sleeping,   0 stopped,   0 zombie  
  35. Cpu(s): 99.7%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  36. Mem:   1035164k total,   695316k used,   339848k free,    26168k buffers  
  37. Swap:  2433836k total,   151692k used,  2282144k free,   349500k cached 
  38.  
  39.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  40. 22690 oracle    20   0  732m  34m  31m R 78.6  3.4   1:07.45 oracle  
  41. 22719 oracle    20   0  732m  30m  27m S 19.9  3.0   0:26.37 oracle 
  42.  
  43. 6. Query the current session  
  44. SQL> select s.username,s.STATUS,p.SPID  
  45. from v$session s, v$process p  
  46. where s.PADDR=p.ADDR and s.username='LIANG' OR s.username='RUSER' order by s.username;  2    3 
  47.  
  48. USERNAME                       STATUS   SPID  
  49. ------------------------------ -------- ------------------------  
  50. RUSER                            ACTIVE   22719  
  51. LIANG                          ACTIVE   22690 
  52.  
  53. 7. Only executes this script by user RUSER, which can obtain all the resource.  
  54. top - 05:29:59 up 7 days, 17:36,  4 users,  load average: 1.04, 0.51, 0.20  
  55. Tasks: 211 total,   2 running, 209 sleeping,   0 stopped,   0 zombie  
  56. Cpu(s): 99.7%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  57. Mem:   1035164k total,   698036k used,   337128k free,    26324k buffers  
  58. Swap:  2433836k total,   151692k used,  2282144k free,   351000k cached 
  59.  
  60.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  61. 22719 oracle    20   0  732m  30m  27m R 98.9  3.0   0:53.12 oracle 
  62.  
  63. 8. Executes this script by both liang and RUSER, the CPU resource was allotted as the resource manager plan.(80/20)  
  64. top - 05:30:47 up 7 days, 17:37,  4 users,  load average: 1.02, 0.58, 0.23  
  65. Tasks: 211 total,   2 running, 209 sleeping,   0 stopped,   0 zombie  
  66. Cpu(s): 99.7%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  67. Mem:   1035164k total,   698160k used,   337004k free,    26404k buffers  
  68. Swap:  2433836k total,   151692k used,  2282144k free,   351048k cached 
  69.  
  70.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  71. 22690 oracle    20   0  732m  34m  31m R 76.0  3.4   2:51.84 oracle  
  72. 22719 oracle    20   0  732m  30m  27m S 23.2  3.0   1:22.57 oracle 
  73.  
  74. 9. Only executes this script by user RUSER, which can obtain all the resource.  
  75. top - 05:31:05 up 7 days, 17:37,  4 users,  load average: 1.01, 0.61, 0.25  
  76. Tasks: 211 total,   2 running, 209 sleeping,   0 stopped,   0 zombie  
  77. Cpu(s): 99.7%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st  
  78. Mem:   1035164k total,   698400k used,   336764k free,    26428k buffers  
  79. Swap:  2433836k total,   151692k used,  2282144k free,   351076k cached 
  80.  
  81.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
  82. 22690 oracle    20   0  732m  34m  31m R 98.8  3.4   3:07.22 oracle  
  83. 22565 oracle    -2   0  730m  15m  13m S  0.7  1.6   0:05.59 oracle