Pular para o conteúdo principal

Monitora Sessões com LAST_CALL_ET alto

create or replace procedure dba_app.monitora_sessions is
vServer VARCHAR2(30) := 'smtp.denilson.com.br';
vSender VARCHAR2(30) := '';
vDest VARCHAR2(100) := '';
vSubj VARCHAR2(50) := 'Verificar Sessão - Produção';
vMesg VARCHAR2(32000):='Verificar Sessão'||UTL_TCP.CRLF;
vManda NUMBER:=0;
l_mail_conn utl_smtp.connection;

BEGIN
l_mail_conn := utl_smtp.open_connection(vServer, 25);
utl_smtp.helo(l_mail_conn, vServer);
utl_smtp.mail(l_mail_conn, vSender);
utl_smtp.rcpt(l_mail_conn, vDest);

utl_smtp.open_data(l_mail_conn );
utl_smtp.write_data(l_mail_conn, 'Subject'||':'|| 'Verificar Sessao - Producao' || UTL_TCP.CRLF);

FOR I IN(select username, sid, serial#, trunc(last_call_et/60) dur
from v$session
where last_call_et > 20*60
and status = 'ACTIVE' )
LOOP

vManda := vManda +1;
vMesg:=vMesg||UTL_TCP.CRLF||rpad(i.username,20,' ' )||' '||'SID:'||' '||rpad(i.sid,5,' ') ||' '||'SERIAL#:'||' '||i.serial#||' '||'TEMPO:'||' '||i.dur||'Min '||UTL_TCP.CRLF;

END LOOP;

dbms_output.put_line(vManda);

if (vManda >= 1) then
utl_smtp.write_data(l_mail_conn,vMesg);
utl_smtp.close_data(l_mail_conn );
utl_smtp.quit(l_mail_conn);
end if;

EXCEPTION WHEN OTHERS THEN
NULL;
END;
/

-- Agendando execução Procedure
BEGIN
DBMS_SCHEDULER.create_job (
job_name => 'sys.monitor_sessions',
job_type => 'PLSQL_BLOCK',
job_action => 'begin monitora_sessions; end;',
start_date => SYSTIMESTAMP,
repeat_interval => 'freq=MINUTELY; INTERVAL=20',
end_date => NULL,
enabled => TRUE,
comments => 'Monitor Sessoes');
END;
/

Comentários

Postagens mais visitadas deste blog

Assign Backup Policy for Boot and Block Volumes - OCI

To get Availability Domain oci iam availability-domain list  #!/bin/bash OCI_AD="hQsi:SA-SAOPAULO-1-AD-1" OCI_COMPARTMENT="ocid1.compartment.oc1..aaaaaaaavgyjpoffz5qliieawamjaksfb6juxejurtduclqjkvv66ookcxja" #Get Silver policy ocid funct_get_policy(){ OCI_POL_OCID=$(oci bv volume-backup-policy list | jq -r '.data[] | select(."display-name"|contains("silver"))' | jq -r '.id') } funct_boot_vol (){ #Create a file with all boot volume ocid oci bv boot-volume list --availability-domain ${OCI_AD} -c  ${OCI_COMPARTMENT} | jq -r '.data[].id' > boot-vol.txt while IFS="" read -r p || [ -n "$p" ] do   printf 'Seeting backup policy for %s\n' "$p"   oci bv volume-backup-policy-assignment create  --asset-id  $p  --policy-id ${OCI_POL_OCID} done < boot-vol.txt } funct_block_vol (){ #Create a file with all block volume ocid oci bv volume list  -c ${OCI_COMPARTMENT} | jq -r '.data[].id' ...

Configurar Tamanho de UNDO e tempo de RETENÇÃO (UNDO_RETENTION)

-- Tamanho Undo Atual SELECT SUM(a.bytes) "UNDO_SIZE" FROM v$datafile a, v$tablespace b, dba_tablespaces c WHERE c.contents = 'UNDO' AND c.status = 'ONLINE' AND b.name = c.tablespace_name AND a.ts# = b.ts#; -- Blocos de UNDO por Seg. SELECT MAX(undoblks/((end_time-begin_time)*3600*24)) "UNDO_BLOCK_PER_SEC" FROM v$undostat; --Tamanho do Bloco SELECT TO_NUMBER(value) "DB_BLOCK_SIZE [KByte]" FROM v$parameter WHERE name = 'db_block_size'; -- Select calcula UNDO RETENTION SELECT d.undo_size/(1024*1024) "ACTUAL UNDO SIZE [MByte]", SUBSTR(e.value,1,25) "UNDO RETENTION [Sec]", ROUND((d.undo_size / (to_number(f.value) * g.undo_block_per_sec))) "OPTIMAL UNDO RETENTION [Sec]" FROM ( SELECT SUM(a.bytes) undo_size FROM v$datafile a, v$tablespace b, dba_tablespaces c WHERE c.contents = 'UNDO' ...

OHS 12c noprompt password when stop/start component

cd $OHS_DOMAIN/bin $ ./stopComponent.sh ohs1 Stopping System Component ohs1 ... Initializing WebLogic Scripting Tool (WLST) ... Welcome to WebLogic Server Administration Scripting Shell Type help() for help on available commands Reading domain from /u01/oracle/domains/ohs_domain Please enter your password : password Connecting to Node Manager ... Successfully Connected to Node Manager. Killing server ohs1 ... Successfully killed server ohs1 Successfully disconnected from Node Manager. Exiting WebLogic Scripting Tool. Done $ OHS_HOME/oracle_common/common/bin $ wlst.sh readDomain('/u01/oracle/domains/ohs_domain') ohs_domain>cd('/SecurityConfiguration/ohs_domain') set('NodeManagerUsername','weblogic') set('NodeManagerPasswordEncrypted','password') updateDomain() closeDomain() exit() $ ./startComponent.sh ohs1  Starting system Component ohs1 ... Initializing WebLogic Scripting Tool (WLST) ... Welco...