myorama
2/27/2017 - 8:42 AM

Install statspack tools and shedules

Install statspack tools and shedules

-- Standalone instance
 
EXEC DBMS_SCHEDULER.DROP_JOB('perfstat.sp_snapshot');
 
BEGIN
  STATSPACK.SNAP(i_snap_level => 7, i_modify_parameter => 'true');
 
  DBMS_SCHEDULER.CREATE_JOB(
    job_name        => 'perfstat.sp_snapshot',
    job_type        => 'STORED_PROCEDURE',
    job_action      => 'perfstat.statspack.snap',
    start_date      => TRUNC(sysdate,'HH') + INTERVAL '1' HOUR,
    repeat_interval => 'FREQ=HOURLY',
    enabled         => TRUE,
    auto_drop       => FALSE,
    comments        => 'Statspack collection'
  );
END;
/
-- for both standalone and clustered instances
 
EXEC DBMS_SCHEDULER.DROP_JOB('perfstat.sp_purge');
CREATE OR REPLACE PROCEDURE perfstat.sp_purge_auto (num_days INTEGER) IS
BEGIN
  FOR inst IN (SELECT dbid, instance_number AS id FROM stats$database_instance) LOOP
    perfstat.statspack.purge(
      i_num_days        => num_days,
      i_dbid            => inst.dbid,
      i_instance_number => inst.id
    );
  END LOOP;
  COMMIT;
END sp_purge_auto;
/
 
BEGIN
  DBMS_SCHEDULER.CREATE_JOB(
    job_name        => 'perfstat.sp_purge',
    job_type        => 'STORED_PROCEDURE',
    job_action      => 'perfstat.sp_purge_auto',
    start_date      => trunc(sysdate,'DD')+47/48,
    repeat_interval => 'FREQ=DAILY;BYHOUR=23;BYMINUTE=30',
    enabled         => FALSE,
    auto_drop       => FALSE,
    comments        => 'Statspack purge collection older than defined days'
  );
 
  DBMS_SCHEDULER.SET_ATTRIBUTE( 
    name      => 'perfstat.sp_purge', 
    attribute => 'number_of_arguments', 
    VALUE     => '1'
  );
 
  DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE( 
    job_name          => 'perfstat.sp_purge', 
    argument_position => 1, 
    argument_value    => '7'
  );
 
  DBMS_SCHEDULER.ENABLE(name=> 'perfstat.sp_purge');
END;
/
CREATE TABLESPACE perfstat DATAFILE '+DATA' SIZE 56M AUTOEXTEND ON MAXSIZE 1G;

define perfstat_password=******
define default_tablespace=perfstat
define temporary_tablespace=temp

@?/rdbms/admin/spcreate

-- regenerate idle events
delete from STATS$IDLE_EVENT;
insert into STATS$IDLE_EVENT select name from V$EVENT_NAME where wait_class='Idle';
commit;
BEGIN
  DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE( 
    job_name          => 'perfstat.sp_purge', 
    argument_position => 1, 
    argument_value    => '30'
  );
END;
/
-- Clustered instances
 
EXEC DBMS_SCHEDULER.DROP_JOB('perfstat.sp_snapshot_1');
EXEC DBMS_SCHEDULER.DROP_JOB('perfstat.sp_snapshot_2');
 
BEGIN
  FOR inst IN (SELECT dbid, inst_id AS id FROM gv$database) LOOP
    STATSPACK.MODIFY_STATSPACK_PARAMETER(
      i_snap_level      => 7,
      i_dbid            => inst.dbid,
      i_instance_number => inst.id
    );
 
    DBMS_SCHEDULER.CREATE_JOB(
      job_name        => 'perfstat.sp_snapshot_' || inst.id,
      job_type        => 'STORED_PROCEDURE',
      job_action      => 'perfstat.statspack.snap',
      start_date      => TRUNC(sysdate,'HH') + INTERVAL '1' HOUR,
      repeat_interval => 'FREQ=HOURLY',
      enabled         => TRUE,
      auto_drop       => FALSE,
      comments        => 'Statspack collection for instance #' || inst.id
    );
 
    DBMS_SCHEDULER.SET_ATTRIBUTE(
      name => 'perfstat.sp_snapshot_' || inst.id,
      attribute => 'instance_id',
      VALUE => inst.id
    );
  END LOOP;
END;
/
-- exécuter un snapshot sur les DEUX INSTANCES
EXEC perfstat.statspack.snap;
 
variable jobno NUMBER;
BEGIN
  FOR inst IN (SELECT dbid, inst_id AS id FROM gv$database) LOOP
    STATSPACK.MODIFY_STATSPACK_PARAMETER(
      i_snap_level      => 7,
      i_dbid            => inst.dbid,
      i_instance_number => inst.id
    );
 
    DBMS_JOB.SUBMIT(
      job       => :jobno, 
      what      => 'perfstat.statspack.snap;', 
      next_date => TRUNC(sysdate,'HH') + INTERVAL '1' HOUR, 
      INTERVAL  => 'INTERVAL ''1'' HOUR',
      no_parse  => TRUE, 
      instance  => inst.id
    );
 
    COMMIT;
  END LOOP;
END;
/