Monday, 14 January 2019

Oracle Database Crontab script on linux system and Email Alert on mail

Scripts details to monitor database Check list


  •  Rman Backup 
  •  Disk Alert 
  • Mount Point 
  • Mount Point Threshold 
  • Expdp Backup 
  • Sar Output 
  • DR Check 
  • Tablespace Alert 
  •  Tablespace Alert Threshhold 
  •  Health Check Daily  
  •  DB Health
  •  Archive I/O
  •  Oracle Alert log monitor 
  •  Stats Gathers Schema 
  •  DATABASE STARTUP DOWN CHECK 




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




  • Crontab list details scheduled in linux OS

oracle@02:~> crontab -l



########### Rman Backup  Script #############



05 04 * * * /u04/MasterDB/scripts/rman_DB_FULL.sh 2>&1 >>/u04/MasterDB/rmanbackup_PRODB/RMAN_PRODB_FULL.log



########### Rman Backup Status on Mail  #############





35 06 * * * /u04/MasterDB/scripts/daily_health_check/rmanbackupstatus.sh



#### OS Disk Alert #################



#0,15,30,45 * * * * /u04/MasterDB/scripts/disk_threshod.sh



#05 05 * * * /u04/MasterDB/scripts/mountpoint_check.sh



#0,15,30,45 * * * * /u04/MasterDB/scripts/DR_check/diskalert_threshold.sh



#### Sar Output ######################



26 09 * * * /u04/MasterDB/scripts/daily_health_check/sar_output/sar.sh



#### DR Check ########################



0 */6 * * * /u04/MasterDB/scripts/DR_check/dr_check.sh



#### Tablespace Alert ###############







0 */12 * * * /u04/MasterDB/scripts/daily_health_check/tablespace_details.sh



#### Tablespace Alert ###############



0,15,30,45 * * * * /u04/MasterDB/scripts/daily_health_check/tablespace_threshold.ksh > /u04/MasterDB/scripts/daily_health_check/ts_alert.log  2>&1



#### Daily Database Health Check ###################



30 04 * * * /u04/MasterDB/scripts/daily_health_check/daily_healthcheck.sh



30 05 * * 1 /u04/MasterDB/scripts/weekly_health_check/Weekly_healthcheck.sh



#### Database Health Check ###################



#30 05 * * * /home/oracle/dbhealth.sh



#### Archive I/O ###################



30 04 * * * /u04/MasterDB/scripts/daily_health_check/archive_IO/archive_IO.sh



#### Alert log monitor #############







10,20,30,40,50,00 * * * * /u04/MasterDB/scripts/alert_log/alert_monitor.sh > /u04/MasterDB/scripts/alert_log/alert_monitor.log1 2>&1



10,20,30,40,50,00 * * * * /u04/MasterDB/scripts/alert_log/check_alert_log.sh > /u04/MasterDB/scripts/alert_log/alert_monitor11.log1 2>&1



##################### Stats Gathers Schema ###################################



0 4 * * 0 /u04/MasterDB/scripts/SMRPRODB_statsgather.sh



################################  SMR DATABASE STARTUP DOWN CHECK #######################



5,10,15,20,25,30,35,40,45,50,55,00 * * * * /u04/MasterDB/scripts/smr_prod_check_instance.sh > /u04/MasterDB/scripts/smr_prod_check_alert_monitor.log 2>&1

oracle@test02:~>







#### Expdp Backup ####################



25 06 * * * /u04/MasterDB/scripts/expdp_smrprodb_full.sh 2>&1 >>/u04/MasterDB/expdp/RODB_FULL.log | mail -s "EXPDP Production database backup logs" varun.yadav@mailid.com

















oracle@02:~> crontab -l



########### Rman Backup  Script #############



05 04 * * * /u04/MasterDB/scripts/rman_DB_FULL.sh 2>&1 >>/u04/MasterDB/rmanbackup_PRODB/RMAN_PRODB_FULL.log



########### Rman Backup Status on Mail  #############



35 06 * * * /u04/MasterDB/scripts/daily_health_check/rmanbackupstatus.sh







#### OS Disk Alert #################



0 */12 * * * /u04/MasterDB/scripts/daily_health_check/mount_point.sh



#### Expdp Backup ####################



25 06 * * * /u04/MasterDB/scripts/expdp_smrprodb_full.sh 2>&1 >>/u04/MasterDB/expdp/RODB_FULL.log | mail -s "EXPDP Production database backup logs" varun.yadav@mailid.com







#### Sar Output ######################



26 09 * * * /u04/MasterDB/scripts/daily_health_check/sar_output/sar.sh



#### DR Check ########################



0 */6 * * * /u04/MasterDB/scripts/DR_check/dr_check.sh



#### Tablespace Alert ###############







0 */12 * * * /u04/MasterDB/scripts/daily_health_check/tablespace_details.sh



0,15,30,45 * * * * /u04/MasterDB/scripts/daily_health_check/tablespace_threshold.ksh > /u04/MasterDB/scripts/daily_health_check/ts_alert.log  2>&1



0,15,30,45 * * * * /u04/MasterDB/scripts/check_tablespace.sh > /u04/MasterDB/scripts/daily_health_check/ts_alert1.log  2>&1







#### Health Check ###################



30 04 * * * /u04/MasterDB/scripts/daily_health_check/daily_healthcheck.sh



30 05 * * 1 /u04/MasterDB/scripts/weekly_health_check/Weekly_healthcheck.sh



#30 05 * * * /home/oracle/dbhealth.sh







#### Archive I/O ###################



30 04 * * * /u04/MasterDB/scripts/daily_health_check/archive_IO/archive_IO.sh







#### Alert log monitor #############







10,20,30,40,50,00 * * * * /u04/MasterDB/scripts/alert_log/alert_monitor.sh > /u04/MasterDB/scripts/alert_log/alert_monitor.log1 2>&1



10,20,30,40,50,00 * * * * /u04/MasterDB/scripts/alert_log/check_alert_log.sh > /u04/MasterDB/scripts/alert_log/alert_monitor11.log1 2>&1



##################### Mount Point#########################







0 */12 * * * /u04/MasterDB/scripts/daily_health_check/mount_point.sh







##################### Stats Gathers Schema ###################################







0 4 * * 0 /u04/MasterDB/scripts/PRODB_statsgather.sh



################################  DATABASE STARTUP DOWN CHECK #######################



5,10,15,20,25,30,35,40,45,50,55,00 * * * * /u04/MasterDB/scripts/prod_check_instance.sh > /u04/MasterDB/scripts/prod_check_alert_monitor.log 2>&1


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


  • Rman Backup 
  •  Disk Alert 
  • Mount Point 
  • Mount Point Threshold 
  • Expdp Backup 
  • Sar Output 
  • DR Check 
  • Tablespace Alert 
  •  Tablespace Alert Threshhold 
  •  Health Check Daily  
  •  DB Health
  •  Archive I/O
  •  Oracle Alert log monitor 
  •  Stats Gathers Schema 
  •  DATABASE STARTUP DOWN CHECK 

##################################  RMAN BACKUP #####################################



oracle@test02:~> cat /u04/MasterDB/scripts/rman_PRODB_FULL.sh

ORACLE_HOME=/u02/app/oracle/product/12.1.0/dbhome_1

DD=`date +%d%m%y`

export ORACLE_HOME

ORACLE_SID=PRODB

export ORACLE_SID

Rman_Log=/u04/MasterDB/scripts/"$ORACLE_SID"_bkp${DD}.log

touch $Rman_Log

/u02/app/oracle/product/12.1.0/dbhome_1/bin/rman target test/test1234 @/u04/MasterDB/scripts/rman_PRODB_FULL.rcv >> /u03/rmanbackup_PRODB/rman_RODB_FULL.log

oracle@test02:~>





oracle@test02:~> cat /u04/MasterDB/scripts/rman_PRODB_FULL.rcv

run

{

allocate channel c1 device type disk format '/u03/rmanbackup_SMRPRODB/Backup_%d_DB_%u_%s_%p_%T';

allocate channel c2 device type disk format '/u03/rmanbackup_SMRPRODB/Backup_%d_DB_%u_%s_%p_%T';

allocate channel c3 device type disk format '/u03/rmanbackup_SMRPRODB/Backup_%d_DB_%u_%s_%p_%T';

allocate channel c4 device type disk format '/u03/rmanbackup_SMRPRODB/Backup_%d_DB_%u_%s_%p_%T';

crosscheck backup;

crosscheck archivelog all;

report obsolete;

delete noprompt obsolete;

sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

backup full database format '/u03/rmanbackup_PRODB/%d_%U.bckp' plus archivelog;

copy current controlfile to '/u03/rmanbackup_PRODB/control01_%d_%T_%U.bak';

backup current controlfile for standby format '/u03/rmanbackup_RODB/standbycontrol_%d_%T_%U.ctl';

release channel c1;

release channel c2;

release channel c3;

release channel c4;

}

oracle@test02:~>





############################ Rman Backup Status  ################################################





oracle@test02:~> cat /u04/MasterDB/scripts/daily_health_check/rmanbackupstatus.sh

. /home/oracle/.bash_profile

DR_log=/u04/MasterDB/scripts/daily_health_check/rmanbackupstatus.log

printf "to:varun.yadav@abc.com\n" > $DR_log

#printf "cc:abc@abccom,core@abc.com\n" >> $DR_log

printf "subject: SMRPRODB Database  RMAN Backup STATUS AND DETAILS " >> $DR_log



sqlplus -s "/as sysdba" <<EOF >> $DR_log



set lines 200

PROMPT DATABASE NAME

PROMPT =================

Select name,open_mode,database_role,db_unique_name from v\$database;



PROMPT RMAN backup and Size Details

PROMPT ==================================================

set lines 200

col START_TIME for a15

col END_TIME for a15

col TIME_TAKEN_DISPLAY for a10

col INPUT_BYTES_DISPLAY heading "DATA SIZE" for a10

col OUTPUT_BYTES_DISPLAY heading "Backup Size" for a11

col OUTPUT_BYTES_PER_SEC_DISPLAY heading "Speed/s" for a10

col output_device_type heading "Device_TYPE" for a11

SELECT to_char (start_time,'DD-MON-YY HH24:MI') START_TIME, to_char(end_time,'DD-MON-YY HH24:MI') END_TIME, time_taken_display, status,

input_type, output_device_type,input_bytes_display, output_bytes_display, output_bytes_per_sec_display ,COMPRESSION_RATIO

FROM v\$rman_backup_job_details

WHERE end_time > sysdate -3;

select ctime "Date"

        , decode(backup_type, 'L', 'Archive Log', 'D', 'Full', 'Incremental') backup_type

        , bsize "Size MB"

   from (select trunc(bp.completion_time) ctime

           , backup_type

           , round(sum(bp.bytes/1024/1024),2) bsize

      from v\$backup_set bs, v\$backup_piece bp

      where bs.set_stamp = bp.set_stamp

     and bs.set_count  = bp.set_count

     and bp.status = 'A'

     group by trunc(bp.completion_time), backup_type)

 order by 1, 2;

EOF

/usr/sbin/sendmail -t < $DR_log

oracle@test02:~>





#### Disk Alert #################



oracle@test02:~> cat /u04/MasterDB/scripts/disk_threshod.sh

# Shell script to monitor or watch the disk space

# It will send an email to $ADMIN, if the (free avilable) percentage

# of space is >= 90%

# -------------------------------------------------------------------------

# Copyright (c) 2005 nixCraft project <http://cyberciti.biz/fb/>

# This script is licensed under GNU GPL version 2.0 or above

# -------------------------------------------------------------------------

# This script is part of nixCraft shell script collection (NSSC)

# Visit http://bash.cyberciti.biz/ for more information.

# ----------------------------------------------------------------------

# Linux shell script to watch disk space (should work on other UNIX oses )

# SEE URL: http://www.cyberciti.biz/tips/shell-script-to-watch-the-disk-space.html

# set admin email so that you can get email

ADMIN="varun.yadav@abc.com"

# set alert level 90% is default

ALERT=90

df -H | grep -vE '^Filesystem|tmpfs|cdrom' | awk '{ print $5 " " $1 }' | while read output;

do

  #echo $output

  usep=$(echo $output | awk '{ print $1}' | cut -d'%' -f1  )

  partition=$(echo $output | awk '{ print $2 }' )

  if [ $usep -ge $ALERT ]; then

  i  echo "Running out of space \"$partition ($usep%)\" on $(hostname) as on $(date)" |

     mail -s " Alert: Almost out of disk space" $usep $ADMIN

  fi

done

oracle@test02:~>





###########################  EXPDP ###########################



oracle@test02:~> cat /u04/MasterDB/scripts/expdp_smrprodb_full.sh

export ORACLE_BASE=/u02/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/12.1.0/dbhome_1

export ORACLE_SID=PRODB

export PATH=$PATH:$ORACLE_HOME/bin

 expdp abc/abc@PRODB dumpfile=expdp-$(date +%Y-%m-%d_%H-%M-%S).dmp directory=expdp logfile=expdp-$(date +%Y-%m-%d_%H-%M-%S).log FULL=Y EXCLUDE=STATISTICS CONTENT=ALL JOB_NAME=FULL_EXPDP_PRODB parallel=2

#Moving log files

mv /u04/MasterDB/expdp/expdp*.log /u04/MasterDB/expdp/expdp_fulldb_backup_logs

#Granting permissions for Dump files

chmod -R 775 /u04/MasterDB/expdp/

#Compressing files

gzip /u04/MasterDB/expdp/*.*

#Removing 2 days old dump files

#find /u04/MasterDB/expdp/ -mtime +2 -exec rm {} \;

oracle@test02:~>





#### Sar Output ######################





oracle@test02:~> cat /u04/MasterDB/scripts/daily_health_check/sar_output/sar.sh

DD=`date +%d%m%y`

cd /u04/MasterDB/scripts/daily_health_check/sar_output

touch /u04/MasterDB/scripts/daily_health_check/sar_output/sar_${DD}.log

sar 3600 24 > /u04/MasterDB/scripts/daily_health_check/sar_output/sar_${DD}.log

cat /u04/MasterDB/scripts/daily_health_check/sar_output/sar_${DD}.log >> /u04/MasterDB/scripts/daily_health_check/sar_output/sar.tmp



mailx -s " Hourly OS CPU Utilization SAR Details " abc@abc.com< sar.tmp

rm -rf sar.tmp

exit

oracle@test02:~>





#### DR Check ########################



oracle@test02:~> cat /u04/MasterDB/scripts/DR_check/dr_check.sh

#*******DR HOURLY STATUS REPORT*******

#

# Prepared by VARUN YADAV.

#

#*************************************

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

#Setting Oracle Environment Variables

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

. /home/oracle/.bash_profile



DR_log=/u04/MasterDB/scripts/DR_check/DR_Status.log



printf "to:abc@abc.com\n" > $DR_log

#printf "cc:abc@abc.com\n" >> $DR_log

printf "subject:  DR HOURLY STATUS REPORT " >> $DR_log



printf "\nDR Status report for `uname -n` at `date` \n" >> $DR_log



sqlplus -s "/as sysdba" <<EOF >> $DR_log



set lines 200

select name, instance_name,db_unique_name, open_mode, database_role, flashback_on  current_scn,to_char(standby_became_primary_scn) failover_scn from v\$database,v\$instance;

SELECT ARCH.THREAD# "Thread", ARCH.SEQUENCE# "Last Sequence Received", APPL.SEQUENCE# "Last Sequence Applied", (ARCH.SEQUENCE# - APPL.SEQUENCE#) "Difference" FROM (SELECT THREAD# ,SEQUENCE# FROM V\$ARCHIVED_LOG WHERE (THREAD#,FIRST_TIME ) IN (SELECT THREAD#,MAX(FIRST_TIME) FROM V\$ARCHIVED_LOG GROUP BY THREAD#)) ARCH, (SELECT THREAD# ,SEQUENCE# FROM V\$LOG_HISTORY WHERE (THREAD#,FIRST_TIME ) IN (SELECT THREAD#,MAX(FIRST_TIME) FROM V\$LOG_HISTORY GROUP BY THREAD#)) APPL WHERE ARCH.THREAD# = APPL.THREAD#;

EOF

/usr/sbin/sendmail -t < $DR_log



oracle@test02:~> /u04/MasterDB/scripts/DR_check/dr_check.sh



#### Tablespace Alert ###############



oracle@test02:~> cat /u04/MasterDB/scripts/daily_health_check/tablespace_details.sh

#*******DR HOURLY STATUS REPORT*******

#

# Prepared by VARUN YADAV.

#

#*************************************

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

#Setting Oracle Environment Variables

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

. /home/oracle/.bash_profile



DR_log1=/u04/MasterDB/scripts/daily_health_check/tb_check.log



printf "to:abc@abc.com\n" > $DR_log1

#printf "cc:core_oradba@mind-infotech.com\n" >> $DR_log1

printf "subject: PRODB Tablespace HOURLY STATUS REPORT\n" >> $DR_log1



#printf "\nDR Status report for `uname -n` at `date` \n" >> $DR_log1



sqlplus -s "/as sysdba" <<EOF >> $DR_log1

et echo off

set feed off

set verify off

set serverout on

set wrap off

set pages 300

set lines 200

col file_name for a50

col name for a50

col member for a50

col file_id for a5

col "Percent Used" for a20

col segment_name for a30

col tablespace_name for a60

col STATUS for a16

col owner for a20

col table_name for a35

col index_name for a35

col owner for a20

col object_type for a20

col object_name for a30



COLUMN TABLESPACE FORMAT A25



select name DBNAME from v\$database;



prompt =======================================================================

prompt                       TABLESPACE   UTILIZATION

prompt =======================================================================



select t.tablespace,  t.totalspace as " Totalspace(MB)",

round((t.totalspace-nvl(fs.freespace,0)),2) as "Used Space(MB)",

nvl(fs.freespace,0) as "Freespace(MB)",

round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) as "%Used",

round((nvl(fs.freespace,0)/t.totalspace)*100,2) as "% Free"

from

(select round(sum(d.bytes)/(1024*1024)) as totalspace,d.tablespace_name tablespace

from dba_data_files d

group by d.tablespace_name) t,

(select round(sum(f.bytes)/(1024*1024)) as freespace,f.tablespace_name tablespace

from dba_free_space f

group by f.tablespace_name) fs

where t.tablespace=fs.tablespace (+)

order by t.tablespace



/



prompt ========================================================================

prompt                           Tablespace  More Than 85% used

prompt ========================================================================



select t.tablespace,  t.totalspace as " Totalspace(MB)",

round((t.totalspace-nvl(fs.freespace,0)),2) as "Used Space(MB)",

nvl(fs.freespace,0) as "Freespace(MB)",

round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) as "%Used",

round((nvl(fs.freespace,0)/t.totalspace)*100,2) as "% Free"

from

(select round(sum(d.bytes)/(1024*1024)) as totalspace,d.tablespace_name tablespace

from dba_data_files d

group by d.tablespace_name) t,

(select round(sum(f.bytes)/(1024*1024)) as freespace,f.tablespace_name tablespace

from dba_free_space f

group by f.tablespace_name) fs

where t.tablespace=fs.tablespace (+)

and round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) >=85

order by t.tablespace



/





set feedback on

set verify on





prompt ========================================================================

prompt  MOUNTPOINT DETAILS

prompt ========================================================================

!df -h /u01

!df -h /u02

!df -h /u03

!df -h /u04

prompt ========================================================================

prompt  Archive Mountpoint space details

prompt ========================================================================





!df -h /u04/MasterDB/oradata/SMRPRODB/ArchiveLog



prompt ========================================================================

prompt Total size of archive Today

prompt ========================================================================



!du -sh /u04/MasterDB/oradata/PRODB/ArchiveLog

/

EOF

/usr/sbin/sendmail -t < $DR_log1



oracle@test02:~>



######### Tablespace Threshold Alert ###################



oracle@test02:~> cat /u04/MasterDB/scripts/daily_health_check/tablespace_threshold.ksh

#!/bin/sh

export ORACLE_HOME=/u02/app/oracle/product/12.1.0/dbhome_1

export PATH=$ORACLE_HOME/bin:$PATH

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

export ORACLE_SID=PRODB

cd /u04/MasterDB/scripts/daily_health_check

logfile=/u04/MasterDB/scripts/daily_health_check/Tablespace_alert.log

cnt1=`ps -ef|grep pmon|grep $ORACLE_SID|wc -l`

if [ $cnt1 -eq 1 ];

then

sqlplus -s "/as sysdba" > /dev/null << EOF

spool $logfile

@/u04/MasterDB/scripts/daily_health_check//tablespace_alert.sql

spool off

exit

EOF

# If there are more then these two lines in the output file, mail it.

count=`cat $logfile|wc -l`

#echo $count

if [ $count  -ge 4 ];

 then

  mailx -s "ALERT: 90 % Threshold Alert FOR PROD Database  "coredba@abc.com <$logfile

fi

fi

oracle@test02:~>





#### ######Database Health Check ###################



oracle@test02:~> cat /u04/MasterDB/scripts/weekly_health_check/Weekly_healthcheck.sh

. /home/oracle/.bash_profile

DR_log=/u04/MasterDB/scripts/weekly_health_check/SMRWeeklyreport.log

printf "to:abc@abc.com\n" > $DR_log

printf "subject: Weekly SMRPRODB Database Healthcheck Details " >> $DR_log







sqlplus -s "/as sysdba" <<EOF >> $DR_log

sqlplus -s "/as sysdba" <<EOF >> $DR_log

set serverout on

set wrap off

set pages 300

set lines 200

col file_name for a50

col name for a50

col member for a50

col file_id for a5

col "Percent Used" for a20

col segment_name for a30

col tablespace_name for a60

col STATUS for a16

col owner for a20

col table_name for a35

col index_name for a35

col owner for a20

col object_type for a20

col object_name for a30



#column date_column new_value today_var



/



select to_char(sysdate,'yyyy-Mon-dd_hh-miAM')date_column from dual



/



spool /u04/MasterDB/scripts/daily_health_check/SMRPROD_&today_var.txt



PROMPT =============================================================

PROMPT DATABASE HEALTH CHECK REPORT

PROMPT =============================================================

PROMPT CURRENT DATE and TIME

PROMPT ======================

Select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') "Current Date/Time" from dual;

PROMPT

PROMPT DATABASE NAME

PROMPT =================

set lines 200

select name, instance_name,db_unique_name, open_mode, database_role, flashback_on  current_scn,to_char(standby_became_primary_scn) failover_scn from v\$database,v\$instance;

PROMPT

PROMPT Users logged information

PROMPT ===============================

select status,count(*) from v\$session

--where username not in ('SYS','SYSTEM')

group by status;

PROMPT

PROMPT Previous day archive logs generation

PROMPT ======================================

select count(*) from v\$archived_log

where to_char(COMPLETION_TIME,'DD-Mon-YY')=to_char(sysdate-1,'DD-Mon-YY');

PROMPT



PROMPT latest Archive No.

PROMPT ======================================

archive log list

PROMPT

PROMPT CONTROL FILES

PROMPT ==================

select * from v\$controlfile;

PROMPT

PROMPT LOG FILE GROUPS

PROMPT ==================

set lines 200



col status for a7

col type for a7

col member for a60

col IS_RECOVERY_DEST_FILE for a3

select GROUP#,STATUS,TYPE,MEMBER,IS_RECOVERY_DEST_FILE from v\$logfile;

PROMPT

PROMPT

PROMPT LOG FILE MEMBERS

PROMPT ==================

select * from v\$log;





PROMPT

PROMPT SIZE OF DATABASE Daily

PROMPT ==================

SET LINESIZE 200

SET PAGESIZE 200

COL "Database Size" FORMAT a13

COL "Used Space" FORMAT a17

COL "Used in %" FORMAT a17

COL "Free in %" FORMAT a17

COL "Database Name" FORMAT a17

COL "Free Space" FORMAT a17

COL "Growth DAY" FORMAT a17

COL "Growth WEEK" FORMAT a17

COL "Growth DAY in %" FORMAT a17

COL "Growth WEEK in %" FORMAT a17

SELECT

(select min(creation_time) from v\$datafile) "Created",

(select name from v\$database) "DB Name",

ROUND((SUM(USED.BYTES) / 1024 / 1024 ),2) || ' MB' "Database Size",

ROUND((SUM(USED.BYTES) / 1024 / 1024 ) - ROUND(FREE.P / 1024 / 1024 ),2) || ' MB' "Used Space",

ROUND(((SUM(USED.BYTES) / 1024 / 1024 ) - (FREE.P / 1024 / 1024 )) / ROUND(SUM(USED.BYTES) / 1024 / 1024 ,2)*100,2) || '% MB' "Used in %",

ROUND((FREE.P / 1024 / 1024 ),2) || ' MB' "Free Space",

ROUND(((SUM(USED.BYTES) / 1024 / 1024 ) - ((SUM(USED.BYTES) / 1024 / 1024 ) - ROUND(FREE.P / 1024 / 1024 )))/ROUND(SUM(USED.BYTES) / 1024 / 1024,2 )*100,2) || '% MB' "F

ree in %",

ROUND(((SUM(USED.BYTES) / 1024 / 1024 ) - (FREE.P / 1024 / 1024 ))/(select sysdate-min(creation_time) from v\$datafile),2) || ' MB' "Growth DAY",

ROUND(((SUM(USED.BYTES) / 1024 / 1024 ) - (FREE.P / 1024 / 1024 ))/(select sysdate-min(creation_time) from v\$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024 ),2)*100,3)

 || '% MB' "Growth DAY in %",

ROUND(((SUM(USED.BYTES) / 1024 / 1024 ) - (FREE.P / 1024 / 1024 ))/(select sysdate-min(creation_time) from v\$datafile)*7,2) || ' MB' "Growth WEEK",

ROUND((((SUM(USED.BYTES) / 1024 / 1024 ) - (FREE.P / 1024 / 1024 ))/(select sysdate-min(creation_time) from v\$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024 ),2)*100)*

7,3) || '% MB' "Growth WEEK in %"

FROM (SELECT BYTES FROM V\$DATAFILE UNION ALL SELECT BYTES FROM V\$TEMPFILE UNION ALL SELECT BYTES FROM V\$LOG) USED, (SELECT SUM(BYTES) AS P FROM DBA_FREE_SPACE) FREE

GROUP BY FREE.P;

PROMPT

PROMPT SIZE OF DATABASE

PROMPT ==================

select 'Data files',sum(bytes)/1024/1024/1024 from dba_data_files

union

select 'Temp Files',sum(bytes)/1024/1024/1024 from dba_temp_files

union

select 'Log files',sum(bytes*members)/1024/1024/1024 from v\$log

union

select 'segments',sum(bytes)/1024/1024/1024 from dba_segments

union

select 'free space',sum(bytes)/1024/1024/1024 from dba_free_space;

PROMPT

PROMPT TABLESPACES AND DATAFILES

PROMPT ============================

col TABLESPACE_NAME for a20

col file_id for a7

col TABLESPACE_NAME for a30

col file_name for a60

col STATUS for a9

select TABLESPACE_NAME, to_char(file_id, '999') "File_id", FILE_NAME, BYTES/1024/1024 "Size in MB" , STATUS

from dba_data_files

order by TABLESPACE_NAME, file_name;

PROMPT

PROMPT DATAFILES Details in AutoExtend Mode

PROMPT ====================================

set lines 200

col FILE_NAME for a60

col tablespace_name for a30

col AUTOEXTENSIBLE for a3

col bytes a10

select file_name,tablespace_name,AUTOEXTENSIBLE,bytes/1024/1024/1024 "SIZE IN GB " from dba_data_files

where  AUTOEXTENSIBLE='YES' order by tablespace_name;

PROMPT

PROMPT UTILIZATION OF TABLESPACES

PROMPT ============================

set lines 200

COLUMN TABLESPACE FORMAT A15



select t.tablespace,  t.totalspace as " Totalspace(MB)",

round((t.totalspace-nvl(fs.freespace,0)),2) as "Used Space(MB)",

nvl(fs.freespace,0) as "Freespace(MB)",

round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) as "%Used",

round((nvl(fs.freespace,0)/t.totalspace)*100,2) as "% Free"

from

(select round(sum(d.bytes)/(1024*1024)) as totalspace,d.tablespace_name tablespace

from dba_data_files d

group by d.tablespace_name) t,

(select round(sum(f.bytes)/(1024*1024)) as freespace,f.tablespace_name tablespace

from dba_free_space f

group by f.tablespace_name) fs

where t.tablespace=fs.tablespace (+)

order by t.tablespace;

PROMPT

PROMPT TABLESPACES utl >85

PROMPT ============================

COLUMN TABLESPACE FORMAT A15

select t.tablespace,  t.totalspace as " Totalspace(MB)",

round((t.totalspace-nvl(fs.freespace,0)),2) as "Used Space(MB)",

nvl(fs.freespace,0) as "Freespace(MB)",

round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) as "%Used",

round((nvl(fs.freespace,0)/t.totalspace)*100,2) as "% Free"

from

(select round(sum(d.bytes)/(1024*1024)) as totalspace,d.tablespace_name tablespace

from dba_data_files d

group by d.tablespace_name) t,

(select round(sum(f.bytes)/(1024*1024)) as freespace,f.tablespace_name tablespace

from dba_free_space f

group by f.tablespace_name) fs

where t.tablespace=fs.tablespace (+)

and round(((t.totalspace-nvl(fs.freespace,0))/t.totalspace)*100,2) >=85

order by t.tablespace

/



PROMPT OBJECTS WHOSE STATUS ARE INVALID

PROMPT ===================================

Rem Check object status

select OBJECT_NAME, owner, object_type, STATUS from all_objects where

object_type in

('FUNCTION','INDEX', 'LIBRARY','PACKAGE','PACKAGE BODY',

'PROCEDURE', 'SEQUENCE','SYNONYM','TABLE','TRIGGER',

'TYPE','UNDEFINED','VIEW')

and status = 'INVALID'

and OWNER not in ('SYS','SYSTEM')

and status is not null ;

PROMPT FILES THAT NEEDS RECOVERY

PROMPT =============================

Rem Check wether there is any data file that needs media recovery

select * from v\$recover_file;

PROMPT

PROMPT



PROMPT

PROMPT Database users detail

PROMPT =====================

set lines 200

col username for a25

col account_status for a10

col default_tablespace for a20

select username,account_status,default_tablespace from dba_users;

PROMPT

PROMPT

PROMPT Last Modified Tables Details

PROMPT =====================

set lines 500;

col TABLE_OWNER for a30

col TABLE_NAME for a40

col TIMESTAMP for a70

select TABLE_OWNER, TABLE_NAME, INSERTS, UPDATES, DELETES,

to_char(TIMESTAMP,'YYYY-MON-DD HH24:MI:SS')

from all_tab_modifications

where table_owner<>'SYS' and

EXTRACT(YEAR FROM TO_DATE(TIMESTAMP, 'DD-MON-RR')) > 2017

order by 6;

PROMPT

PROMPT

PROMPT  Total Objects

PROMPT =========================

set lines 140

col owner for a30

select owner as "SCHEMA",count(*) from dba_objects

group by owner;

PROMPT

PROMPT Archive Log generation History for Last one month

PROMPT ==================================================

set lines 200

SELECT to_date(first_time) DAY, to_char(sum(decode(to_char(first_time,'HH24'),'00',1,0)),'999') "00",

to_char(sum(decode(to_char(first_time,'HH24'),'01',1,0)),'999') "01",

to_char(sum(decode(to_char(first_time,'HH24'),'02',1,0)),'999') "02",

to_char(sum(decode(to_char(first_time,'HH24'),'03',1,0)),'999') "03",

to_char(sum(decode(to_char(first_time,'HH24'),'04',1,0)),'999') "04",

to_char(sum(decode(to_char(first_time,'HH24'),'05',1,0)),'999') "05",

to_char(sum(decode(to_char(first_time,'HH24'),'06',1,0)),'999') "06",

to_char(sum(decode(to_char(first_time,'HH24'),'07',1,0)),'999') "07",

to_char(sum(decode(to_char(first_time,'HH24'),'08',1,0)),'999') "08",

to_char(sum(decode(to_char(first_time,'HH24'),'09',1,0)),'999') "09",

to_char(sum(decode(to_char(first_time,'HH24'),'10',1,0)),'999') "10",

to_char(sum(decode(to_char(first_time,'HH24'),'11',1,0)),'999') "11",

to_char(sum(decode(to_char(first_time,'HH24'),'12',1,0)),'999') "12",

to_char(sum(decode(to_char(first_time,'HH24'),'13',1,0)),'999') "13",

to_char(sum(decode(to_char(first_time,'HH24'),'14',1,0)),'999') "14",

to_char(sum(decode(to_char(first_time,'HH24'),'15',1,0)),'999') "15",

to_char(sum(decode(to_char(first_time,'HH24'),'16',1,0)),'999') "16",

to_char(sum(decode(to_char(first_time,'HH24'),'17',1,0)),'999') "17",

to_char(sum(decode(to_char(first_time,'HH24'),'18',1,0)),'999') "18",

to_char(sum(decode(to_char(first_time,'HH24'),'19',1,0)),'999') "19",

to_char(sum(decode(to_char(first_time,'HH24'),'20',1,0)),'999') "20",

to_char(sum(decode(to_char(first_time,'HH24'),'21',1,0)),'999') "21",

to_char(sum(decode(to_char(first_time,'HH24'),'22',1,0)),'999') "22",

to_char(sum(decode(to_char(first_time,'HH24'),'23',1,0)),'999') "23"

from v\$log_history where to_date(first_time) > sysdate -30 GROUP by to_char(first_time,'YYYY-MON-DD'),

to_date(first_time) order by to_date(first_time)

;

PROMPT

PROMPT

PROMPT dba_jobs assinged

PROMPT ==================================================

set lines 100 pages 999

col        schema_user format a15

col        fails format 999

select        job

,        schema_user

,        to_char(last_date, 'hh24:mi dd/mm/yy') last_run

,        to_char(next_date, 'hh24:mi dd/mm/yy') next_run

,        failures fails

,        broken

,        substr(what, 1, 15) what

from        dba_jobs

order by 4

/

PROMPT

PROMPT

PROMPT List all materialized view logs

PROMPT ==================================================

select log_owner,log_table from dba_mview_logs

/



PROMPT

PROMPT

PROMPT Show all materialized and resfresh times

PROMPT ==================================================

set lines 100 pages 999

col last_refresh format a20

select owner,mview_name,to_char(last_refresh_date,'dd/mm/yy hh24:mi') last_refresh

from dba_mviews

order by owner, last_refresh

/



PROMPT

PROMPT

PROMPT Show materialized view tables and masters

PROMPT ==================================================

set lines 100

col mview format a40

col master format a40

select        owner || '.' || name mview

,        master_owner || '.' || master master

from        dba_mview_refresh_times

/

PROMPT

PROMPT

PROMPT This is useful for spotting failures

PROMPT ==================================================

set lines 100

col job format 9999

col log_user format a15

col last format a15

col next format a15

col fail format 9999

col what format a20

select        job

,        log_user

,        to_char(last_date, 'dd/mm/yy hh24:mi') last

,        to_char(next_date, 'dd/mm/yy hh24:mi') next

,        failures fail

,        replace(what, '"') what

from        dba_jobs

where        what like '%dbms_refresh.refresh%'

/

prompt ========================================================================

prompt  Rman Backup details

prompt ========================================================================



set lines 200

col START_TIME for a15

col END_TIME for a15

col TIME_TAKEN_DISPLAY for a10

col INPUT_BYTES_DISPLAY heading "DATA SIZE" for a10

col OUTPUT_BYTES_DISPLAY heading "Backup Size" for a11

col OUTPUT_BYTES_PER_SEC_DISPLAY heading "Speed/s" for a10

col output_device_type heading "Device_TYPE" for a11

SELECT to_char (start_time,'DD-MON-YY HH24:MI') START_TIME, to_char(end_time,'DD-MON-YY HH24:MI') END_TIME, time_taken_display, status,

input_type, output_device_type,input_bytes_display, output_bytes_display, output_bytes_per_sec_display ,COMPRESSION_RATIO

FROM v\$rman_backup_job_details

WHERE end_time > sysdate -3;

prompt ========================================================================

prompt  MOUNTPOINT DETAILS

prompt ========================================================================

!df -h /u01

!df -h /u02

!df -h /u03

!df -h /u04

prompt ========================================================================

prompt  Archive Mountpoint space details

prompt ========================================================================

!df -h /u04/MasterDB/oradata/SMRPRODB/ArchiveLog

prompt ========================================================================

prompt Total size of archive Today

prompt ========================================================================



!du -sh /u04/MasterDB/oradata/SMRPRODB/ArchiveLog

prompt ========================================================================

prompt  DR SYNC STATUS

prompt ========================================================================





SELECT ARCH.THREAD# "Thread", ARCH.SEQUENCE# "Last Sequence Received", APPL.SEQUENCE# "Last Sequence Applied", (ARCH.SEQUENCE# - APPL.SEQUENCE#) "Difference" FROM (SELECT THREAD# ,SEQUENCE# FROM V\$ARCHIVED_LOG WHERE (THREAD#,FIRST_TIME ) IN (SELECT THREAD#,MAX(FIRST_TIME) FROM V\$ARCHIVED_LOG GROUP BY THREAD#)) ARCH, (SELECT THREAD# ,SEQUENCE# FROM V\$LOG_HISTORY WHERE (THREAD#,FIRST_TIME ) IN (SELECT THREAD#,MAX(FIRST_TIME) FROM V\$LOG_HISTORY GROUP BY THREAD#)) APPL WHERE ARCH.THREAD# = APPL.THREAD#;

/

EOF

/usr/sbin/sendmail -t < $DR_log

oracle@test02:~>



############# Database health check deeply######



oracle@test02:~> cat /home/oracle/dbhealth.sh

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

# DATABASE DAILY HEALTH CHECK MONITORING SCRIPT

VER="[3.9]"

# ===============================================================================

# CAUTION:

# THIS SCRIPT MAY CAUSE A SLIGHT PERFORMANCE IMPACT WHEN IT RUN,

# I RECOMMEND TO NOT RUN THIS SCRIPT SO FREQUENT.

# E.G. YOU MAY CONSIDER TO SCHEDULE IT TO RUN ONE TIME BETWEEN 12:00AM to 5:00AM.

# ===============================================================================

#

# FEATURES:

# CHECKING CPU UTILIZATION.

# CHECKING FILESYSTEM UTILIZATION.

# CHECKING TABLESPACES UTILIZATION.

# CHECKING FLASH RECOVERY AREA UTILIZATION.

# CHECKING ASM DISKGROUPS UTILIZATION.

# CHECKING BLOCKING SESSIONS ON THE DATABASE.

# CHECKING UNUSABLE INDEXES ON THE DATABASE.

# CHECKING INVALID OBJECTS ON THE DATABASE.

# CHECKING FAILED LOGIN ATTEMPTS ON THE DATABASE.

# CHEKCING AUDIT RECORDS ON THE DATABASE.

# CHECKING CORRUPTED BLOCKS ON THE DATABASE.

# CHECKING FAILED JOBS IN THE DATABASE.

# CHECKING ACTIVE INCIDENTS.

# CHECKING OUTSTANDING ALERTS.

# CHECKING DATABASE SIZE GROWTH.

# CHECKING OS / HARDWARE STATISTICS.

# CHECKING RESOURCE LIMITS.

# CHECKING RECYCLEBIN.

# CHECKING CURRENT RESTORE POINTS.

# CHECKING HEALTH MONITOR CHECKS RECOMMENDATIONS THAT RUN BY DBMS_HM PACKAGE.

# CHEKCING MONITORED INDEXES.

# CHECKING REDOLOG SWITCHES.

# CHECKING MODIFIED INTIALIZATION PARAMETERS SINCE THE LAST DB STARTUP.

# CHECKING ADVISORS RECOMMENDATIONS:

#      - SQL TUNING ADVISOR

#      - SGA ADVISOR

#      - PGA ADVISOR

#      - BUFFER CACHE ADVISOR

#      - SHARED POOL ADVISOR

#      - SEGMENT ADVISOR

#

#                   #   #     #

# Author:   Mahmmoud ADEL         # # # #   ###

#                   #   #   # #   #

#

# Created:      22-12-13 Based on dbalarm.sh script.

# Modifications:18-05-14 Added Filsystem monitoring.

#       19-05-14 Added CPU monitoring.

#       09-12-14 Added Tablespaces monitoring

#            Added BLOCKING SESSIONS monitoring

#            Added UNUSABLE INDEXES monitoring

#            Added INVALID OBJECTS monitoring

#            Added FAILED LOGINS monitoring

#            Added AUDIT RECORDS monitoring

#            Added CORRUPTED BLOCKS monitoring

#            [It will NOT run a SCAN. It will look at V$DATABASE_BLOCK_CORRUPTION]

#            Added FAILED JOBS monitoring.

#       06-10-15 Replaced mpstat with iostat for CPU Utilization Check

#       02-11-15 Enhanced "FAILED JOBS monitoring" part.

#               13-12-15 Added Advisors Recommendations to the report

#               04-04-16 dba_tablespace_usage_metrics view will be used for 11g onwards versions

#                        for checking tablespaces size, advised by: Satyajit Mohapatra

#               10-04-16 Add Flash Recovery Area monitoring

#               10-04-16 Add ASM Disk Groups monitoring

#       15-07-16 Add ACTIVE INCIDENTS, RESOURCE LIMITS, RECYCLEBIN, RESTORE POINTS,

#             MONITORED INDEXES, REDOLOG SWITCHES, MODIFIED SPFILE PARAMETERS checks.

#       02-01-17 Removed ALERTLOG check for DB & Listener +

#            Merged alerts with advisors.       [Recommended by: ABD-ELGAWAD]

#       03-01-17 Added checking RAC status feature.     [Recommended by: Samer ALJazzar]

#       09-01-17 Added RMAN BACKUP CHECK.

#       04-05-17 Added Reporting of Newly Created Objects in the last 24Hours.

#       12-06-17 Added Long Running Jobs Alert.

#       20-07-17 Neutralize login.sql if found under Oracle user home directory due to bugs.

#               10-10-17 Added reporting Long Running Queries to the report.

#

#

#

#

#

#

#

#

#

#

#

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

SCRIPT_NAME="dbdailychk${VER}"

SRV_NAME=`uname -n`

MAIL_LIST="abc@abc.com"



    case ${MAIL_LIST} in "youremail@yourcompany.com")

     echo

     echo "##############################################################################################"

     echo "You Missed Something :-)"

     echo "In order to receive the HEALTH CHECK report via Email, you have to ADD your E-mail at line# 90"

     echo "by replacing this template [youremail@yourcompany.com] with YOUR E-mail address."

     echo "DB HEALTH CHECK report will be saved on disk..."

     echo "##############################################################################################"

     echo;;

    esac



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

# THRESHOLDS:

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

# Send an E-mail for each THRESHOLD if been reached:

# ADJUST the following THRESHOLD VALUES as per your requirements:



FSTHRESHOLD=95      # THRESHOLD FOR FILESYSTEM %USED                [OS]

CPUTHRESHOLD=95     # THRESHOLD FOR CPU %UTILIZATION                [OS]

TBSTHRESHOLD=95     # THRESHOLD FOR TABLESPACE %USED                [DB]

FRATHRESHOLD=95         # THRESHOLD FOR FLASH RECOVERY AREA %USED               [DB]

ASMTHRESHOLD=95         # THRESHOLD FOR ASM DISK GROUPS                         [DB]

UNUSEINDXTHRESHOLD=1    # THRESHOLD FOR NUMBER OF UNUSABLE INDEXES          [DB]

INVOBJECTTHRESHOLD=1    # THRESHOLD FOR NUMBER OF INVALID OBJECTS           [DB]

FAILLOGINTHRESHOLD=1    # THRESHOLD FOR NUMBER OF FAILED LOGINS             [DB]

AUDITRECOTHRESHOLD=1    # THRESHOLD FOR NUMBER OF AUDIT RECORDS                 [DB]

CORUPTBLKTHRESHOLD=1    # THRESHOLD FOR NUMBER OF CORRUPTED BLOCKS          [DB]

FAILDJOBSTHRESHOLD=1    # THRESHOLD FOR NUMBER OF FAILED JOBS               [DB]

JOBSRUNSINCENDAY=1  # THRESHOLD FOR JOBS RUNNING LONGER THAN N DAY          [DB]

NEWOBJCONTTHRESHOLD=1   # THRESHOLD FOR NUMBER OF NEWLY CREATED OBJECTS         [DB]

LONG_RUN_QUR_HOURS=1    # THRESHOLD FOR QUERIES RUNNING LONGER THAN N HOURS             [DB]



# CHECK DATABASE AUDIT RECORDS: [Expected to increase CPU Load during script execution when enabled]

CHKAUDITRECORDS=Y



# CHECK CLUSTERWARE HEALTH:

CLUSTER_CHECK=Y



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

# Excluded INSTANCES:

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

# Here you can mention the instances dbalarm will IGNORE and will NOT run against:

# Use pipe "|" as a separator between each instance name.

# e.g. Excluding: -MGMTDB, ASM instances:



EXL_DB="\-MGMTDB|ASM"           #Excluding INSTANCES [Will get excluded from the report].



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

# Excluded ERRORS:

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

# Here you can exclude the errors that you don't want to be alerted when they appear in the logs:

# Use pipe "|" between each error.



EXL_ALERT_ERR="ORA-2396|TNS-00507|TNS-12502|TNS-12560|TNS-12537|TNS-00505"              #Excluded ALERTLOG ERRORS [Will not get reported].

EXL_LSNR_ERR="TNS-00507|TNS-12502|TNS-12560|TNS-12537|TNS-00505"                        #Excluded LISTENER ERRORS [Will not get reported].





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

# Excluded FILESYSTEM/MOUNT POINTS:

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

# Here you can exclude specific filesystems/mount points from being reported by dbalarm:

# e.g. Excluding: /dev/mapper, /dev/asm mount points:



EXL_FS="\/dev\/mapper\/|\/dev\/asm\/"                                                   #Excluded mount points [Will be skipped during the check].



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

# Checking The FILESYSTEM:

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



# Report Partitions that reach the threshold of Used Space:



FSLOG=/tmp/filesystem_DBA_BUNDLE.log

echo "[Reported By ${SCRIPT_NAME} Script]"       > ${FSLOG}

echo ""                                         >> ${FSLOG}

df -h                                           >> ${FSLOG}

df -h | grep -v "^Filesystem" |awk '{print substr($0, index($0, $2))}'| egrep -v "${EXL_FS}"|awk '{print $(NF-1)" "$NF}'| while read OUTPUT

   do

        PRCUSED=`echo ${OUTPUT}|awk '{print $1}'|cut -d'%' -f1`

        FILESYS=`echo ${OUTPUT}|awk '{print $2}'`

                if [ ${PRCUSED} -ge ${FSTHRESHOLD} ]

                 then

mail -s "ALARM: Filesystem [${FILESYS}] on Server [${SRV_NAME}] has reached ${PRCUSED}% of USED space" ${MAIL_LIST} < ${FSLOG}

                fi

   done



rm -f ${FSLOG}





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

# Checking The CPU Utilization:

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



# Report CPU Utilization if reach >= CPUTHRESHOLD:

OS_TYPE=`uname -s`

CPUUTLLOG=/tmp/CPULOG_DBA_BUNDLE.log



# Getting CPU utilization in last 5 seconds:

case `uname` in

        Linux ) CPU_REPORT_SECTIONS=`iostat -c 1 5 | sed -e 's/,/./g' | tr -s ' ' ';' | sed '/^$/d' | tail -1 | grep ';' -o | wc -l`

        CPU_COUNT=`cat /proc/cpuinfo|grep processor|wc -l`

                        if [ ${CPU_REPORT_SECTIONS} -ge 6 ]; then

                           CPU_IDLE=`iostat -c 1 5 | sed -e 's/,/./g' | tr -s ' ' ';' | sed '/^$/d' | tail -1| cut -d ";" -f 7`

                        else

                           CPU_IDLE=`iostat -c 1 5 | sed -e 's/,/./g' | tr -s ' ' ';' | sed '/^$/d' | tail -1| cut -d ";" -f 6`

                        fi

        ;;

        AIX )   CPU_IDLE=`iostat -t $INTERVAL_SEC $NUM_REPORT | sed -e 's/,/./g'|tr -s ' ' ';' | tail -1 | cut -d ";" -f 6`

        CPU_COUNT=`lsdev -C|grep Process|wc -l`

        ;;

        SunOS ) CPU_IDLE=`iostat -c $INTERVAL_SEC $NUM_REPORT | tail -1 | awk '{ print $4 }'`

        CPU_COUNT=`psrinfo -v|grep "Status of processor"|wc -l`

        ;;

        HP-UX)  SAR="/usr/bin/sar"

        CPU_COUNT=`lsdev -C|grep Process|wc -l`

                if [ ! -x $SAR ]; then

                 echo "sar command is not supported on your environment | CPU Check ignored"; CPU_IDLE=99

                else

                 CPU_IDLE=`/usr/bin/sar 1 5 | grep Average | awk '{ print $5 }'`

                fi

        ;;

        *) echo "uname command is not supported on your environment | CPU Check ignored"; CPU_IDLE=99

        ;;

        esac



# Getting Utilized CPU (100-%IDLE):

CPU_UTL_FLOAT=`echo "scale=2; 100-($CPU_IDLE)"|bc`



# Convert the average from float number to integer:

CPU_UTL=${CPU_UTL_FLOAT%.*}



    if [ -z ${CPU_UTL} ]

     then

      CPU_UTL=1

    fi



# Compare the current CPU utilization with the Threshold:

CPULOG=/tmp/top_processes_DBA_BUNDLE.log



        if [ ${CPU_UTL} -ge ${CPUTHRESHOLD} ]

     then

                export COLUMNS=300           #Increase the COLUMNS width to display the full output [Default is 167]

        echo "CPU STATS:"     >  ${CPULOG}

                echo "========="      >> ${CPULOG}

        mpstat 1 5        >> ${CPULOG}

        echo ""           >> ${CPULOG}

                echo "VMSTAT Output:"     >> ${CPULOG}

                echo "============="      >> ${CPULOG}

        echo "[If the runqueue number in the (r) column exceeds the number of CPUs [${CPU_COUNT}] this indicates a CPU bottleneck on the system]." >> ${CPULOG}

                echo ""                   >> ${CPULOG}

        vmstat 2 5        >> ${CPULOG}

                echo ""                   >> ${CPULOG}

        echo "Top 10 Processes:"  >> ${CPULOG}

        echo "================"   >> ${CPULOG}

        echo ""           >> ${CPULOG}

        top -c -b -n 1|head -17   >> ${CPULOG}

                unset COLUMNS                #Set COLUMNS width back to the default value

        #ps -eo pcpu,pid,user,args | sort -k 1 -r | head -11 >> ${CPULOG}

# Check ACTIVE SESSIONS on DB side:

for ORACLE_SID in $( ps -ef|grep pmon|grep -v grep|egrep -v ${EXL_DB}|awk '{print $NF}'|sed -e 's/ora_pmon_//g'|grep -v sed|grep -v "s///g" )

   do

    export ORACLE_SID



# Getting ORACLE_HOME:

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

  ORA_USER=`ps -ef|grep ${ORACLE_SID}|grep pmon|egrep -v ${EXL_DB}|awk '{print $1}'|tail -1`

  USR_ORA_HOME=`grep ${ORA_USER} /etc/passwd| cut -f6 -d ':'|tail -1`



# SETTING ORATAB:

if [ -f /etc/oratab ]

  then

  ORATAB=/etc/oratab

  export ORATAB

## If OS is Solaris:

elif [ -f /var/opt/oracle/oratab ]

  then

  ORATAB=/var/opt/oracle/oratab

  export ORATAB

fi



# ATTEMPT1: Get ORACLE_HOME using pwdx command:

  PMON_PID=`pgrep  -lf _pmon_${ORACLE_SID}|awk '{print $1}'`

  export PMON_PID

  ORACLE_HOME=`pwdx ${PMON_PID}|awk '{print $NF}'|sed -e 's/\/dbs//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from PWDX is ${ORACLE_HOME}"



# ATTEMPT2: If ORACLE_HOME not found get it from oratab file:

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

## If OS is Linux:

if [ -f /etc/oratab ]

  then

  ORATAB=/etc/oratab

  ORACLE_HOME=`grep -v '^\#' $ORATAB | grep -v '^$'| grep -i "^${ORACLE_SID}:" | perl -lpe'$_ = reverse' | cut -f3 | perl -lpe'$_ = reverse' |cut -f2 -d':'`

  export ORACLE_HOME



## If OS is Solaris:

elif [ -f /var/opt/oracle/oratab ]

  then

  ORATAB=/var/opt/oracle/oratab

  ORACLE_HOME=`grep -v '^\#' $ORATAB | grep -v '^$'| grep -i "^${ORACLE_SID}:" | perl -lpe'$_ = reverse' | cut -f3 | perl -lpe'$_ = reverse' |cut -f2 -d':'`

  export ORACLE_HOME

fi

#echo "ORACLE_HOME from oratab is ${ORACLE_HOME}"

fi



# ATTEMPT3: If ORACLE_HOME is still not found, search for the environment variable: [Less accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`env|grep -i ORACLE_HOME|sed -e 's/ORACLE_HOME=//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from environment  is ${ORACLE_HOME}"

fi



# ATTEMPT4: If ORACLE_HOME is not found in the environment search user's profile: [Less accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`grep -h 'ORACLE_HOME=\/' $USR_ORA_HOME/.bash_profile $USR_ORA_HOME/.*profile | perl -lpe'$_ = reverse' |cut -f1 -d'=' | perl -lpe'$_ = reverse'|tail -1`

  export ORACLE_HOME

#echo "ORACLE_HOME from User Profile is ${ORACLE_HOME}"

fi



# ATTEMPT5: If ORACLE_HOME is still not found, search for orapipe: [Least accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`locate -i orapipe|head -1|sed -e 's/\/bin\/orapipe//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from orapipe search is ${ORACLE_HOME}"

fi





# Check Long Running Transactions if CPUDIGMORE=Y:

                 case ${CPUDIGMORE} in

                 y|Y|yes|YES|Yes)

${ORACLE_HOME}/bin/sqlplus -s '/ as sysdba' << EOF

set linesize 200

SPOOL ${CPULOG} APPEND

prompt

prompt ----------------------------------------------------------------



Prompt ACTIVE SESSIONS ON DATABASE $ORACLE_SID:

prompt ----------------------------------------------------------------



set feedback off linesize 200 pages 1000

col "OS_PID" for a8

col module for a30

col event for a27

col "USER|SID,SER# |MOD|MACHINE" for a60

col WAIT_STATE for a25

col "STATUS|WAIT_STATE|TIME_WAITED" for a31

col "CURR_SQLID" for a35

col "SQLID | FULL_SQL_TEXT" for a75

select p.spid "OS_PID",s.USERNAME||'|'||s.sid||','||s.serial#||' | '||substr(s.MODULE,1,27)||'|'||substr(s.MACHINE,1,20) "USER|SID,SER# |MOD|MACHINE",

substr(s.status||'|'||w.state||'|'||w.seconds_in_wait||'|'||LAST_CALL_ET||'|'||LOGON_TIME,1,50) "ST|WA_ST|WAITD|ACTIVE|LOGIN",

substr(s.status||'|'||w.state||'|'||w.seconds_in_wait||'sec',1,30) "STATUS|WAIT_STATE|TIME_WAITED",

--substr(w.event,1,30)"EVENT",s.SQL_ID ||' | '|| Q.SQL_FULLTEXT "SQLID | FULL_SQL_TEXT"

substr(w.event,1,30)"EVENT",s.SQL_ID

from v\$session s,v\$process p, v\$session_wait w, v\$SQL Q

where s.username is not null

and s.status='ACTIVE'

and p.addr = s.paddr

and s.sid=w.sid

and s.SQL_ID=Q.SQL_ID

order by s.USERNAME||' | '||s.sid||','||s.serial#,s.MODULE;



prompt

prompt ----------------------------------------------------------------



Prompt Long Running Operations On DATABASE $ORACLE_SID:

prompt ----------------------------------------------------------------



col "USER | SID,SERIAL#" for a40

col MESSAGE for a80

col "%COMPLETE" for 999.99

col "SID|SERIAL#" for a12

    set linesize 200

    select USERNAME||' | '||SID||','||SERIAL# "USER | SID,SERIAL#",SQL_ID,START_TIME,SOFAR/TOTALWORK*100 "%COMPLETE",

    trunc(ELAPSED_SECONDS/60) MIN_ELAPSED, trunc(TIME_REMAINING/60) MIN_REMAINING,substr(MESSAGE,1,80)MESSAGE

    from v\$session_longops where SOFAR/TOTALWORK*100 <>'100'

    order by MIN_REMAINING;



SPOOL OFF

EOF



        ;;

        esac

  done

mail -s "ALERT: CPU Utilization on Server [${SRV_NAME}] has reached [${CPU_UTL}%]" ${MAIL_LIST} < ${CPULOG}

    fi



rm -f ${CPUUTLLOG}

rm -f ${CPULOG}



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

# Getting ORACLE_SID:

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

# Exit with sending Alert mail if No DBs are running:

INS_COUNT=$( ps -ef|grep pmon|grep -v grep|grep -Ev ${EXL_DB}|wc -l )

    if [ $INS_COUNT -eq 0 ]

     then

     echo "[Reported By ${SCRIPT_NAME} Script]"                          > /tmp/oracle_processes_DBA_BUNDLE.log

     echo " "                                       >> /tmp/oracle_processes_DBA_BUNDLE.log

     echo "Current running INSTANCES on server [${SRV_NAME}]:"              >> /tmp/oracle_processes_DBA_BUNDLE.log

     echo "***************************************************"             >> /tmp/oracle_processes_DBA_BUNDLE.log

     ps -ef|grep -v grep|grep pmon                              >> /tmp/oracle_processes_DBA_BUNDLE.log

         echo " "                                                                               >> /tmp/oracle_processes_DBA_BUNDLE.log

         echo "Current running LISTENERS on server [${SRV_NAME}]:"                              >> /tmp/oracle_processes_DBA_BUNDLE.log

         echo "***************************************************"                         >> /tmp/oracle_processes_DBA_BUNDLE.log

         ps -ef|grep -v grep|grep tnslsnr                                                       >> /tmp/oracle_processes_DBA_BUNDLE.log

mail -s "ALARM: No Databases Are Running on Server ${SRV_NAME} !!!" ${MAIL_LIST}         < /tmp/oracle_processes_DBA_BUNDLE.log

     rm -f /tmp/oracle_processes_DBA_BUNDLE.log

     exit

    fi



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

# Setting ORACLE_SID:

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

for ORACLE_SID in $( ps -ef|grep pmon|grep -v grep|egrep -v ${EXL_DB}|awk '{print $NF}'|sed -e 's/ora_pmon_//g'|grep -v sed|grep -v "s///g" )

   do

    export ORACLE_SID



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

# Getting ORACLE_HOME

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

  ORA_USER=`ps -ef|grep ${ORACLE_SID}|grep pmon|grep -v grep|egrep -v ${EXL_DB}|awk '{print $1}'|tail -1`

  USR_ORA_HOME=`grep ${ORA_USER} /etc/passwd| cut -f6 -d ':'|tail -1`



# SETTING ORATAB:

if [ -f /etc/oratab ]

  then

  ORATAB=/etc/oratab

  export ORATAB

## If OS is Solaris:

elif [ -f /var/opt/oracle/oratab ]

  then

  ORATAB=/var/opt/oracle/oratab

  export ORATAB

fi



# ATTEMPT1: Get ORACLE_HOME using pwdx command:

  PMON_PID=`pgrep  -lf _pmon_${ORACLE_SID}|awk '{print $1}'`

  export PMON_PID

  ORACLE_HOME=`pwdx ${PMON_PID}|awk '{print $NF}'|sed -e 's/\/dbs//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from PWDX is ${ORACLE_HOME}"



# ATTEMPT2: If ORACLE_HOME not found get it from oratab file:

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

## If OS is Linux:

if [ -f /etc/oratab ]

  then

  ORATAB=/etc/oratab

  ORACLE_HOME=`grep -v '^\#' $ORATAB | grep -v '^$'| grep -i "^${ORACLE_SID}:" | perl -lpe'$_ = reverse' | cut -f3 | perl -lpe'$_ = reverse' |cut -f2 -d':'`

  export ORACLE_HOME



## If OS is Solaris:

elif [ -f /var/opt/oracle/oratab ]

  then

  ORATAB=/var/opt/oracle/oratab

  ORACLE_HOME=`grep -v '^\#' $ORATAB | grep -v '^$'| grep -i "^${ORACLE_SID}:" | perl -lpe'$_ = reverse' | cut -f3 | perl -lpe'$_ = reverse' |cut -f2 -d':'`

  export ORACLE_HOME

fi

#echo "ORACLE_HOME from oratab is ${ORACLE_HOME}"

fi



# ATTEMPT3: If ORACLE_HOME is still not found, search for the environment variable: [Less accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`env|grep -i ORACLE_HOME|sed -e 's/ORACLE_HOME=//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from environment  is ${ORACLE_HOME}"

fi



# ATTEMPT4: If ORACLE_HOME is not found in the environment search user's profile: [Less accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`grep -h 'ORACLE_HOME=\/' $USR_ORA_HOME/.bash_profile $USR_ORA_HOME/.*profile | perl -lpe'$_ = reverse' |cut -f1 -d'=' | perl -lpe'$_ = reverse'|tail -1`

  export ORACLE_HOME

#echo "ORACLE_HOME from User Profile is ${ORACLE_HOME}"

fi



# ATTEMPT5: If ORACLE_HOME is still not found, search for orapipe: [Least accurate]

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  ORACLE_HOME=`locate -i orapipe|head -1|sed -e 's/\/bin\/orapipe//g'`

  export ORACLE_HOME

#echo "ORACLE_HOME from orapipe search is ${ORACLE_HOME}"

fi



# TERMINATE: If all above attempts failed to get ORACLE_HOME location, EXIT the script:

if [ ! -f ${ORACLE_HOME}/bin/sqlplus ]

 then

  echo "Please export ORACLE_HOME variable in your .bash_profile file under oracle user home directory in order to get this script to run properly"

  echo "e.g."

  echo "export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1"

mail -s "dbalarm script on Server [${SRV_NAME}] failed to find ORACLE_HOME, Please export ORACLE_HOME variable in your .bash_profile file under oracle user home directory" ${MAIL_LIST} < /dev/null

exit

fi





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

# Variables:

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

export PATH=$PATH:${ORACLE_HOME}/bin

export LOG_DIR=${USR_ORA_HOME}/BUNDLE_Logs

mkdir -p ${LOG_DIR}

chown -R ${ORA_USER} ${LOG_DIR}

chmod -R go-rwx ${LOG_DIR}



        if [ ! -d ${LOG_DIR} ]

         then

          mkdir -p /tmp/BUNDLE_Logs

          export LOG_DIR=/tmp/BUNDLE_Logs

          chown -R ${ORA_USER} ${LOG_DIR}

          chmod -R go-rwx ${LOG_DIR}

        fi



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

# Neutralize login.sql file: [Bug Fix]

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

# Existance of login.sql file under Oracle user Linux home directory eliminates many functions during the execution of this script from crontab:



        if [ -f ${USR_ORA_HOME}/login.sql ]

         then

mv ${USR_ORA_HOME}/login.sql   ${USR_ORA_HOME}/login.sql_NeutralizedBy${SCRIPT_NAME}

        fi



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

# Getting ORACLE_BASE:

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



# Get ORACLE_BASE from user's profile if it EMPTY:



if [ -z "${ORACLE_BASE}" ]

 then

  ORACLE_BASE=`grep -h 'ORACLE_BASE=\/' $USR_ORA_HOME/.bash* $USR_ORA_HOME/.*profile | perl -lpe'$_ = reverse' |cut -f1 -d'=' | perl -lpe'$_ = reverse'|tail -1`

fi



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

# Getting DB_NAME:

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

VAL1=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" <<EOF

set pages 0 feedback off;

prompt

SELECT name from v\$database

exit;

EOF

)

# Getting DB_NAME in Uppercase & Lowercase:

DB_NAME_UPPER=`echo ${VAL1}| perl -lpe'$_ = reverse' |awk '{print $1}'|perl -lpe'$_ = reverse'`

DB_NAME_LOWER=$( echo "${DB_NAME_UPPER}" | tr -s  '[:upper:]' '[:lower:]' )

export DB_NAME_UPPER

export DB_NAME_LOWER



# DB_NAME is Uppercase or Lowercase?:



     if [ -d ${ORACLE_HOME}/diagnostics/${DB_NAME_LOWER} ]

        then

                DB_NAME=${DB_NAME_LOWER}

        else

                DB_NAME=${DB_NAME_UPPER}

     fi



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

# Getting DB_UNQ_NAME:

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

VAL121=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" <<EOF

set pages 0 feedback off;

prompt

select value from v\$parameter where name='db_unique_name';

exit;

EOF

)

# Getting DB_NAME in Uppercase & Lowercase:

DB_UNQ_NAME=`echo $VAL121| perl -lpe'$_ = reverse' |awk '{print $1}'|perl -lpe'$_ = reverse'`

export DB_UNQ_NAME



# In case DB_UNQ_NAME variable is empty then use DB_NAME instead:

case ${DB_UNQ_NAME}

    in '') DB_UNQ_NAME=${DB_NAME}; export DB_UNQ_NAME;;

esac



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

# Checking DB Version:

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



VAL311=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" <<EOF

set pages 0 feedback off;

prompt

select version from v\$instance;

exit;

EOF

)

DB_VER=`echo $VAL311|perl -lpe'$_ = reverse' |awk '{print $1}'|perl -lpe'$_ = reverse'|cut -f1 -d '.'`





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

# Getting DB Block Size:

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

VAL312=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" <<EOF

set pages 0 feedback off;

prompt

select value from v\$parameter where name='db_block_size';

exit;

EOF

)

blksize=`echo $VAL312|perl -lpe'$_ = reverse' |awk '{print $1}'|perl -lpe'$_ = reverse'|cut -f1 -d '.'`





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

# Getting DB ROLE:

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

VAL312=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" <<EOF

set pages 0 feedback off;

prompt

select DATABASE_ROLE from v\$database;

exit;

EOF

)

DB_ROLE=`echo $VAL312|perl -lpe'$_ = reverse' |awk '{print $1}'|perl -lpe'$_ = reverse'|cut -f1 -d '.'`



        case ${DB_ROLE} in

         PRIMARY) DB_ROLE_ID=0;;

               *) DB_ROLE_ID=1;;

        esac





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

# Checking LONG RUNNING DB JOBS:

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

VAL410=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set pages 0 feedback off echo off;

--SELECT count(*) from dba_scheduler_running_jobs where extract(day FROM elapsed_time) > ${JOBSRUNSINCENDAY} and SESSION_ID is not null;

SELECT count(*) from dba_scheduler_running_jobs where extract(day FROM elapsed_time) > ${JOBSRUNSINCENDAY};

exit;

EOF

)

VAL510=`echo ${VAL410} | awk '{print $NF}'`

                if [ ${VAL510} -ge 1 ]

                 then

VAL610=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set linesize 200 pages 1000

spool ${LOG_DIR}/long_running_jobs.log

PROMPT Long Running Jobs:

PROMPT ^^^^^^^^^^^^^^^^^



col INS for 999

col "JOB_NAME|OWNER|SPID|SID" for a55

col ELAPSED_TIME for a17

col CPU_USED for a17

col "WAIT_SEC"  for 9999999999

col WAIT_CLASS for a15

col "BLKD_BY" for 9999999

col "WAITED|WCLASS|EVENT"       for a45

select j.RUNNING_INSTANCE INS,j.JOB_NAME ||' | '|| j.OWNER||' |'||SLAVE_OS_PROCESS_ID||'|'||j.SESSION_ID"JOB_NAME|OWNER|SPID|SID"

,s.FINAL_BLOCKING_SESSION "BLKD_BY",ELAPSED_TIME,CPU_USED

,substr(s.SECONDS_IN_WAIT||'|'||s.WAIT_CLASS||'|'||s.EVENT,1,45) "WAITED|WCLASS|EVENT",S.SQL_ID

from dba_scheduler_running_jobs j, gv\$session s

where   j.RUNNING_INSTANCE=S.INST_ID(+)

and     j.SESSION_ID=S.SID(+)

and     extract(day FROM elapsed_time) > ${JOBSRUNSINCENDAY}

order by "JOB_NAME|OWNER|SPID|SID",ELAPSED_TIME;



spool off

exit;

EOF

)



mail -s "WARNING: JOBS running for more than ${JOBSRUNSINCENDAY} day detected on database [${DB_NAME_UPPER}] on Server [${SRV_NAME}]" ${MAIL_LIST} < ${LOG_DIR}/long_running_jobs.log

rm -f ${LOG_DIR}/long_running_jobs.log

                fi



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

# Checking FAILED JOBS ON THE DATABASE:

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

VAL40=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set pages 0 feedback off echo off;

--SELECT (SELECT COUNT(*) FROM dba_jobs where failures <> '0') + (SELECT COUNT(*) FROM dba_scheduler_jobs where FAILURE_COUNT <> '0') FAIL_COUNT FROM dual;

SELECT (SELECT COUNT(*) FROM dba_jobs where failures <> '0') + (SELECT COUNT(*) FROM DBA_SCHEDULER_JOB_RUN_DETAILS where LOG_DATE > sysdate-1 and STATUS<>'SUCCEEDED') FAIL_COUNT FROM dual;

exit;

EOF

)

VAL50=`echo ${VAL40} | awk '{print $NF}'`

                if [ ${VAL50} -ge ${FAILDJOBSTHRESHOLD} ]

                 then

VAL60=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set linesize 200 pages 1000

spool ${LOG_DIR}/failed_jobs.log

PROMPT DBMS_JOBS:

PROMPT ^^^^^^^^^^



col LAST_RUN for a25

col NEXT_RUN for a25

set long 9999999

--select dbms_xmlgen.getxml('select job,schema_user,failures,LAST_DATE LAST_RUN,NEXT_DATE NEXT_RUN from dba_jobs where failures <> 0') xml from dual;

select job,schema_user,failures,to_char(LAST_DATE,'DD-Mon-YYYY hh24:mi:ss')LAST_RUN,to_char(NEXT_DATE,'DD-Mon-YYYY hh24:mi:ss')NEXT_RUN from dba_jobs where failures <> '0';



PROMPT

PROMPT DBMS_SCHEDULER:

PROMPT ^^^^^^^^^^^^^^^



col OWNER for a25

col JOB_NAME for a40

col STATE for a11

col STATUS for a11

col FAILURE_COUNT for 999 heading 'Fail'

col RUNTIME_IN_LAST24H for a25

col RUN_DURATION for a14

--HTML format Outputs:

--Set Markup Html On Entmap On Spool On Preformat Off

-- Get the whole failed runs in the last 24 hours:

select to_char(LOG_DATE,'DD-Mon-YYYY hh24:mi:ss')RUNTIME_IN_LAST24H,OWNER,JOB_NAME,STATUS,ERROR#,RUN_DURATION from DBA_SCHEDULER_JOB_RUN_DETAILS where LOG_DATE > sysdate-1 and STATUS<>'SUCCEEDED';



--XML Output

--select dbms_xmlgen.getxml('select to_char(LOG_DATE,''DD-Mon-YYYY hh24:mi:ss'')RUNTIME_IN_LAST24H,OWNER,JOB_NAME,STATUS,ERROR#,RUN_DURATION from DBA_SCHEDULER_JOB_RUN_DETAILS where LOG_DATE > sysdate-1 and STATUS<>''SUCCEEDED''') xml from dual;





spool off

exit;

EOF

)

mail -s "WARNING: FAILED JOBS detected on database [${DB_NAME_UPPER}] on Server [${SRV_NAME}]" ${MAIL_LIST} < ${LOG_DIR}/failed_jobs.log

rm -f ${LOG_DIR}/failed_jobs.log

                fi



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

# LOGFILE SETTINGS:

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



# Logfile path variable:

DB_HEALTHCHK_RPT=${LOG_DIR}/${DB_NAME}_HEALTH_CHECK_REPORT.log

export DB_HEALTHCHK_RPT



# Flush the logfile:

echo "^^^^^^^^^^^"                       > ${DB_HEALTHCHK_RPT}

echo "REPORTED BY: ${SCRIPT_NAME}"      >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^"                      >> ${DB_HEALTHCHK_RPT}

echo ""                                 >> ${DB_HEALTHCHK_RPT}



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

# Checking RAC/ORACLE_RESTART Services:

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



        case ${CLUSTER_CHECK} in

                y|Y|yes|YES|Yes)



# Check for ocssd clusterware process:

CHECK_OCSSD=`ps -ef|grep 'ocssd.bin'|grep -v grep|wc -l`

CHECK_CRSD=`ps -ef|grep 'crsd.bin'|grep -v grep|wc -l`



if [ ${CHECK_CRSD} -gt 0 ]

then

 CLS_STR=crs

 export CLS_STR

 CLUSTER_TYPE=CLUSTERWARE

 export CLUSTER_TYPE

else

 CLS_STR=has

 export CLS_STR

 CLUSTER_TYPE=ORACLE_RESTART

 export CLUSTER_TYPE

fi



    if [ ${CHECK_CRSD} -gt 0 ]

     then



GRID_HOME=`ps -ef|grep 'ocssd.bin'|grep -v grep|awk '{print $NF}'|sed -e 's/\/bin\/ocssd.bin//g'|grep -v sed|grep -v "//g"`

export GRID_HOME



echo "^^^^^^^^^^^^^^^^^^^"                                              >> ${DB_HEALTHCHK_RPT}

echo "CLUSTERWARE CHECKS:"                                              >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^"                                              >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}



FILE_NAME=${GRID_HOME}/bin/ocrcheck

export FILE_NAME

if [ -f ${FILE_NAME} ]

then

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^"                                              >> ${DB_HEALTHCHK_RPT}

echo "OCR DISKS CHECKING:"                                              >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^"                                              >> ${DB_HEALTHCHK_RPT}

${GRID_HOME}/bin/ocrcheck                                               >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

fi



FILE_NAME=${GRID_HOME}/bin/crsctl

export FILE_NAME

if [ -f ${FILE_NAME} ]

then

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^"                                             >> ${DB_HEALTHCHK_RPT}

echo "VOTE DISKS CHECKING:"                                             >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^"                                             >> ${DB_HEALTHCHK_RPT}

${GRID_HOME}/bin/crsctl query css votedisk                              >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

fi

    fi



    if [ ${CHECK_OCSSD} -gt 0 ]

     then



GRID_HOME=`ps -ef|grep 'ocssd.bin'|grep -v grep|awk '{print $NF}'|sed -e 's/\/bin\/ocssd.bin//g'|grep -v sed|grep -v "//g"`

export GRID_HOME



FILE_NAME=${GRID_HOME}/bin/crsctl

export FILE_NAME

if [ -f ${FILE_NAME} ]

then

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^^^^"                                          >> ${DB_HEALTHCHK_RPT}

echo "${CLUSTER_TYPE} SERVICES:"                                        >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^^^^"                                          >> ${DB_HEALTHCHK_RPT}

AWK=/usr/bin/awk

$AWK \

'BEGIN {printf "%-55s %-24s %-18s\n", "HA Resource", "Target", "State";

printf "%-55s %-24s %-18s\n", "-----------", "------", "-----";}'   >> ${DB_HEALTHCHK_RPT}

$GRID_HOME/bin/crsctl status resource | $AWK \

'BEGIN { FS="="; state = 0; }

$1~/NAME/ && $2~/'$1'/ {appname = $2; state=1};

state == 0 {next;}

$1~/TARGET/ && state == 1 {apptarget = $2; state=2;}

$1~/STATE/ && state == 2 {appstate = $2; state=3;}

state == 3 {printf "%-55s %-24s %-18s\n", appname, apptarget, appstate; state=0;}'  >> ${DB_HEALTHCHK_RPT}

fi



FILE_NAME=${ORACLE_HOME}/bin/srvctl

export FILE_NAME

if [ -f ${FILE_NAME} ]

then

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^^^^^"                                         >> ${DB_HEALTHCHK_RPT}

echo "DATABASE SERVICES STATUS:"                                        >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^^^^^^^^^^^"                                         >> ${DB_HEALTHCHK_RPT}

${ORACLE_HOME}/bin/srvctl status service -d ${DB_UNQ_NAME}              >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

fi



    fi

        ;;

        esac



echo ""                                                                 >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^"                                                   >> ${DB_HEALTHCHK_RPT}

echo "Local Filesystem:"                                                >> ${DB_HEALTHCHK_RPT}

echo "^^^^^^^^^^^^^^"                                                   >> ${DB_HEALTHCHK_RPT}

df -h                                                                   >> ${DB_HEALTHCHK_RPT}

echo ""                                                                 >> ${DB_HEALTHCHK_RPT}





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

# Checking Advisors:

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



# If the database version is 10g onward collect the advisors recommendations:

        if [ ${DB_VER} -gt 9 ]

         then



VAL611=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set linesize 200 pages 100

spool ${DB_HEALTHCHK_RPT} app



PROMPT

PROMPT ^^^^^^^^^^^^^^



PROMPT Tablespaces Size:  [Based on Datafiles MAXSIZE]

PROMPT ^^^^^^^^^^^^^^



set pages 1000 linesize 200 tab off

col tablespace_name for A25

col Total_MB for 999999999999

col Used_MB for 999999999999

col '%Used' for 999.99

comp sum of Total_MB on report

comp sum of Used_MB   on report

bre on report

select tablespace_name,

       (tablespace_size*$blksize)/(1024*1024) Total_MB,

       (used_space*$blksize)/(1024*1024) Used_MB,

       used_percent "%Used"

from dba_tablespace_usage_metrics;





PROMPT ^^^^^^^^^^^^^^



PROMPT ASM STATISTICS:

PROMPT ^^^^^^^^^^^^^^



select name,state,OFFLINE_DISKS,total_mb,free_mb,ROUND((1-(free_mb / total_mb))*100, 2) "%FULL" from v\$asm_diskgroup;



PROMPT ^^^^^^^^^^^^^^



PROMPT FRA STATISTICS:

PROMPT ^^^^^^^^^^^^^^



PROMPT

PROMPT FRA_SIZE:

PROMPT ^^^^^^^^^



col name for a35

SELECT NAME,NUMBER_OF_FILES,SPACE_LIMIT/1024/1024/1024 AS TOTAL_SIZE_GB,SPACE_USED/1024/1024/1024 SPACE_USED_GB,

SPACE_RECLAIMABLE/1024/1024/1024 SPACE_RECLAIMABLE_GB,ROUND((SPACE_USED-SPACE_RECLAIMABLE)/SPACE_LIMIT * 100, 1) AS "%FULL_AFTER_CLAIM",

ROUND((SPACE_USED)/SPACE_LIMIT * 100, 1) AS "%FULL_NOW" FROM V\$RECOVERY_FILE_DEST;



PROMPT FRA_COMPONENTS:

PROMPT ^^^^^^^^^^^^^^^^^



select * from v\$flash_recovery_area_usage;



PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT DATABASE GROWTH: [In the Last ~8 days]

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

set serveroutput on

Declare

    v_BaselineSize    number(20);

    v_CurrentSize    number(20);

    v_TotalGrowth    number(20);

    v_Space        number(20);

    cursor usageHist is

            select a.snap_id,

            SNAP_TIME,

            sum(TOTAL_SPACE_ALLOCATED_DELTA) over ( order by a.SNAP_ID) ProgSum

        from

            (select SNAP_ID,

                sum(SPACE_ALLOCATED_DELTA) TOTAL_SPACE_ALLOCATED_DELTA

            from DBA_HIST_SEG_STAT

            group by SNAP_ID

            having sum(SPACE_ALLOCATED_TOTAL) <> 0

            order by 1 ) a,

            (select distinct SNAP_ID,

                to_char(END_INTERVAL_TIME,'DD-Mon-YYYY HH24:Mi') SNAP_TIME

            from DBA_HIST_SNAPSHOT) b

        where a.snap_id=b.snap_id;

Begin

    select sum(SPACE_ALLOCATED_DELTA) into v_TotalGrowth from DBA_HIST_SEG_STAT;

    select sum(bytes) into v_CurrentSize from dba_segments;

    v_BaselineSize := (v_CurrentSize - v_TotalGrowth) ;

    dbms_output.put_line('SNAP_TIME           Database Size(GB)');

    for row in usageHist loop

            v_Space := (v_BaselineSize + row.ProgSum)/(1024*1024*1024);

        dbms_output.put_line(row.SNAP_TIME || '           ' || to_char(v_Space) );

    end loop;

end;

/





PROMPT

PROMPT ^^^^^^^^^^^^^^^^^



PROMPT Active Incidents:

PROMPT ^^^^^^^^^^^^^^^^^



set linesize 200

col RECENT_PROBLEMS_1_WEEK_BACK for a45

select PROBLEM_KEY RECENT_PROBLEMS_1_WEEK_BACK,to_char(FIRSTINC_TIME,'DD-MON-YY HH24:mi:ss') FIRST_OCCURENCE,to_char(LASTINC_TIME,'DD-MON-YY HH24:mi:ss')

LAST_OCCURENCE FROM V\$DIAG_PROBLEM WHERE LASTINC_TIME > SYSDATE -10;

PROMPT

PROMPT OUTSTANDING ALERTS:

PROMPT ^^^^^^^^^^^^^^^^^^^



select * from DBA_OUTSTANDING_ALERTS;



PROMPT

PROMPT CORRUPTED BLOCKS:

PROMPT ^^^^^^^^^^^^^^^^^



select * from V\$DATABASE_BLOCK_CORRUPTION;



PROMPT

PROMPT BLOCKING SESSIONS:

PROMPT ^^^^^^^^^^^^^^^^^^



set linesize 200 pages 0 echo on feedback on

col BLOCKING_STATUS for a90

select 'User: '||s1.username || '@' || s1.machine || '(SID=' || s1.sid ||' ) running SQL_ID:'||s1.sql_id||' is blocking

User: '|| s2.username || '@' || s2.machine || '(SID=' || s2.sid || ') running SQL_ID:'||s2.sql_id||' For '||s2.SECONDS_IN_WAIT||' sec

----------------------------------------------------------------

Warn user '||s1.username||' Or use the following statement to kill his session:

----------------------------------------------------------------

ALTER SYSTEM KILL SESSION '''||s1.sid||','||s1.serial#||''' immediate;' AS blocking_status

from gv\$LOCK l1, gv\$SESSION s1, gv\$LOCK l2, gv\$SESSION s2

 where s1.sid=l1.sid and s2.sid=l2.sid

 and l1.BLOCK=1 and l2.request > 0

 and l1.id1 = l2.id1

 and l2.id2 = l2.id2

 order by s2.SECONDS_IN_WAIT desc;



PROMPT

PROMPT UN-USABLE INDEXES:

PROMPT ^^^^^^^^^^^^^^^^^^



PROMPT

set echo on feedback on pages 1000

select 'ALTER INDEX '||OWNER||'.'||INDEX_NAME||' REBUILD ONLINE;' from dba_indexes where status='UNUSABLE';



PROMPT

PROMPT INVALID OBJECTS:

PROMPT ^^^^^^^^^^^^^^^



PROMPT

set pages 0

select 'alter package '||owner||'.'||object_name||' compile;' from dba_objects where status <> 'VALID' and object_type like '%PACKAGE%' union

select 'alter type '||owner||'.'||object_name||' compile specification;' from dba_objects where status <> 'VALID' and object_type like '%TYPE%'union

select 'alter '||object_type||' '||owner||'.'||object_name||' compile;' from dba_objects where status <> 'VALID' and object_type not in ('PACKAGE','PACKAGE BODY','SYNONYM','TYPE','TYPE BODY') union

select 'alter public synonym '||object_name||' compile;' from dba_objects where status <> 'VALID' and object_type ='SYNONYM';

set pages 1000



PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT RMAN BACKUP OPERATIONS: [LAST 24H]

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^



col START_TIME for a15

col END_TIME for a15

col TIME_TAKEN_DISPLAY for a10

col INPUT_BYTES_DISPLAY heading "DATA SIZE" for a10

col OUTPUT_BYTES_DISPLAY heading "Backup Size" for a11

col OUTPUT_BYTES_PER_SEC_DISPLAY heading "Speed/s" for a10

col output_device_type heading "Device_TYPE" for a11

SELECT to_char (start_time,'DD-MON-YY HH24:MI') START_TIME, to_char(end_time,'DD-MON-YY HH24:MI') END_TIME, time_taken_display, status,

input_type, output_device_type,input_bytes_display, output_bytes_display, output_bytes_per_sec_display ,COMPRESSION_RATIO

FROM v\$rman_backup_job_details

WHERE end_time > sysdate -1;



PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^



PROMPT SCHEDULED JOBS STATUS:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^



PROMPT

PROMPT DBMS_JOBS:

PROMPT ^^^^^^^^^^



set linesize 200

col LAST_RUN for a25

col NEXT_RUN for a25

select job,schema_user,failures,to_char(LAST_DATE,'DD-Mon-YYYY hh24:mi:ss')LAST_RUN,to_char(NEXT_DATE,'DD-Mon-YYYY hh24:mi:ss')NEXT_RUN from dba_jobs;



PROMPT

PROMPT DBMS_SCHEDULER:

PROMPT ^^^^^^^^^^^^^^^^



col OWNER for a15

col STATE for a15

col FAILURE_COUNT for 9999 heading 'Fail'

col "DURATION(d:hh:mm:ss)" for a22

col REPEAT_INTERVAL for a70

col "LAST_RUN || REPEAT_INTERVAL" for a65

col "DURATION(d:hh:mm:ss)" for a12

--col LAST_START_DATE for a40

select JOB_NAME,OWNER,ENABLED,STATE,FAILURE_COUNT,to_char(LAST_START_DATE,'DD-Mon-YYYY hh24:mi:ss')||' || '||REPEAT_INTERVAL "LAST_RUN || REPEAT_INTERVAL",

extract(day from last_run_duration) ||':'||

lpad(extract(hour from last_run_duration),2,'0')||':'||

lpad(extract(minute from last_run_duration),2,'0')||':'||

lpad(round(extract(second from last_run_duration)),2,'0') "DURATION(d:hh:mm:ss)"

from dba_scheduler_jobs order by ENABLED,STATE;



PROMPT

PROMPT Current Running Jobs:

PROMPT ^^^^^^^^^^^^^^^^^^^

col INS             for 999

col "JOB_NAME|OWNER|SPID|SID"   for a55

col ELAPSED_TIME        for a17

col CPU_USED            for a17

col "WAIT_SEC"          for 9999999999

col WAIT_CLASS          for a15

col "BLKD_BY"           for 9999999

col "WAITED|WCLASS|EVENT"   for a45

select j.RUNNING_INSTANCE INS,j.JOB_NAME ||' | '|| j.OWNER||' |'||SLAVE_OS_PROCESS_ID||'|'||j.SESSION_ID"JOB_NAME|OWNER|SPID|SID"

,s.FINAL_BLOCKING_SESSION "BLKD_BY",ELAPSED_TIME,CPU_USED

,substr(s.SECONDS_IN_WAIT||'|'||s.WAIT_CLASS||'|'||s.EVENT,1,45) "WAITED|WCLASS|EVENT",S.SQL_ID

from dba_scheduler_running_jobs j, gv\$session s

where   j.RUNNING_INSTANCE=S.INST_ID(+)

and     j.SESSION_ID=S.SID(+)

order by "JOB_NAME|OWNER|SPID|SID",ELAPSED_TIME;



PROMPT

PROMPT AUTOTASK INTERNAL MAINTENANCE WINDOWS:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



col WINDOW_NAME for a17

col NEXT_RUN for a20

col ACTIVE for a6

col OPTIMIZER_STATS for a15

col SEGMENT_ADVISOR for a15

col SQL_TUNE_ADVISOR for a16

col HEALTH_MONITOR for a15

SELECT WINDOW_NAME,TO_CHAR(WINDOW_NEXT_TIME,'DD-MM-YYYY HH24:MI:SS') NEXT_RUN,AUTOTASK_STATUS STATUS,WINDOW_ACTIVE ACTIVE,OPTIMIZER_STATS,SEGMENT_ADVISOR,SQL_TUNE_ADVISOR,HEALTH_MONITOR FROM DBA_AUTOTASK_WINDOW_CLIENTS;



PROMPT

PROMPT FAILED DBMS_SCHEDULER JOBS IN THE LAST 24H:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



col LOG_DATE for a36

col OWNER for a15

col JOB_NAME for a35

col STATUS for a11

col RUN_DURATION for a20

col ID for 99

select INSTANCE_ID ID,JOB_NAME,OWNER,LOG_DATE,STATUS,ERROR#,RUN_DURATION from DBA_SCHEDULER_JOB_RUN_DETAILS where LOG_DATE > sysdate-1 and STATUS='FAILED' order by JOB_NAME,LOG_DATE;





PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT Queries Running For More Than [${LONG_RUN_QUR_HOURS}] Hours:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



col module for a30

col DURATION_HOURS for 99999.9

col STARTED_AT for a13

col "USERNAME| SID,SERIAL#" for a30

col "SQL_ID | SQL_TEXT" for a120

select username||'| '||sid ||','|| serial# "USERNAME| SID,SERIAL#",substr(MODULE,1,30) "MODULE", to_char(sysdate-last_call_et/24/60/60,'DD-MON HH24:MI') STARTED_AT,

last_call_et/60/60 "DURATION_HOURS"

--||' | '|| (select SQL_FULLTEXT from v\$sql where address=sql_address) "SQL_ID | SQL_TEXT"

,SQL_ID

from v\$session where

username is not null

and module is not null

and last_call_et > 60*60*${LONG_RUN_QUR_HOURS}

and status = 'ACTIVE';





PROMPT ^^^^^^^^^^^^^^^^



PROMPT ADVISORS STATUS:

PROMPT ^^^^^^^^^^^^^^^^



col CLIENT_NAME for a60

col window_group for a60

col STATUS for a15

SELECT client_name, status, consumer_group, window_group FROM dba_autotask_client ORDER BY client_name;



PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT SQL TUNING ADVISOR:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT

PROMPT Last Execution of SQL TUNING ADVISOR:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



col TASK_NAME for a60

set long 2000000000

SELECT task_name, status, TO_CHAR(execution_end,'DD-MON-YY HH24:MI') Last_Execution FROM dba_advisor_executions where TASK_NAME='SYS_AUTO_SQL_TUNING_TASK' and execution_end>sysdate-1;





variable Findings_Report CLOB;

    BEGIN

    :Findings_Report :=DBMS_SQLTUNE.REPORT_AUTO_TUNING_TASK(

    begin_exec => NULL,

    end_exec => NULL,

    type => 'TEXT',

    level => 'TYPICAL',

    section => 'ALL',

    object_id => NULL,

    result_limit => NULL);

    END;

    /

    print :Findings_Report

PROMPT

PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT MEMORY ADVISORS:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT

PROMPT SGA ADVISOR:

PROMPT ^^^^^^^^^^^^



col ESTD_DB_TIME for 99999999999999999

col ESTD_DB_TIME_FACTOR for 9999999999999999999999999999

select * from V\$SGA_TARGET_ADVICE where SGA_SIZE_FACTOR > .6 and SGA_SIZE_FACTOR < 1.6;



PROMPT

PROMPT Buffer Cache ADVISOR:

PROMPT ^^^^^^^^^^^^^^^^^^^^^



col ESTD_SIZE_MB for 9999999999999

col ESTD_PHYSICAL_READS for 99999999999999999999

col ESTD_PHYSICAL_READ_TIME for 99999999999999999999

select SIZE_FACTOR "%SIZE",SIZE_FOR_ESTIMATE ESTD_SIZE_MB,ESTD_PHYSICAL_READS,ESTD_PHYSICAL_READ_TIME,ESTD_PCT_OF_DB_TIME_FOR_READS

from V\$DB_CACHE_ADVICE where SIZE_FACTOR >.8 and SIZE_FACTOR<1.3;



PROMPT

PROMPT Shared Pool ADVISOR:

PROMPT ^^^^^^^^^^^^^^^^^^^^^



col SIZE_MB for 99999999999

col SIZE_FACTOR for 99999999

col ESTD_SIZE_MB for 99999999999999999999

col LIB_CACHE_SAVED_TIME for 99999999999999999999999999

select SHARED_POOL_SIZE_FOR_ESTIMATE SIZE_MB,SHARED_POOL_SIZE_FACTOR "%SIZE",SHARED_POOL_SIZE_FOR_ESTIMATE/1024/1024 ESTD_SIZE_MB,ESTD_LC_TIME_SAVED LIB_CACHE_SAVED_TIME,

ESTD_LC_LOAD_TIME PARSING_TIME from V\$SHARED_POOL_ADVICE

where SHARED_POOL_SIZE_FACTOR > .9 and SHARED_POOL_SIZE_FACTOR  < 1.6;





PROMPT

PROMPT PGA ADVISOR:

PROMPT ^^^^^^^^^^^^



col SIZE_FACTOR  for 999999999

col ESTD_SIZE_MB for 99999999999999999999

col MB_PROCESSED for 99999999999999999999

col ESTD_TIME for 99999999999999999999

select PGA_TARGET_FACTOR "%SIZE",PGA_TARGET_FOR_ESTIMATE/1024/1024 ESTD_SIZE_MB,BYTES_PROCESSED/1024/1024 MB_PROCESSED,

ESTD_TIME,ESTD_PGA_CACHE_HIT_PERCENTAGE PGA_HIT,ESTD_OVERALLOC_COUNT PGA_SHORTAGE

from V\$PGA_TARGET_ADVICE where PGA_TARGET_FACTOR > .7 and PGA_TARGET_FACTOR < 1.6;



PROMPT

PROMPT SEGMENT ADVISOR:

PROMPT ^^^^^^^^^^^^^^^^



select'Task Name : ' || f.task_name || chr(10) ||

'Start Run Time : ' || TO_CHAR(execution_start, 'dd-mon-yy hh24:mi') || chr (10) ||

'Segment Name : ' || o.attr2 || chr(10) ||

'Segment Type : ' || o.type || chr(10) ||

'Partition Name : ' || o.attr3 || chr(10) ||

'Message : ' || f.message || chr(10) ||

'More Info : ' || f.more_info || chr(10) ||

'-------------------------------------------' Advice

FROM dba_advisor_findings f

,dba_advisor_objects o

,dba_advisor_executions e

WHERE o.task_id = f.task_id

AND o.object_id = f.object_id

AND f.task_id = e.task_id

AND e. execution_start > sysdate - 1

AND e.advisor_name = 'Segment Advisor'

ORDER BY f.task_name;





PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT CURRENT OS / HARDWARE STATISTICS:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



select stat_name,value from v\$osstat;



PROMPT

PROMPT ^^^^^^^^^^^^^^^



PROMPT RESOURCE LIMIT:

PROMPT ^^^^^^^^^^^^^^^



col INITIAL_ALLOCATION for a20

col LIMIT_VALUE for a20

select * from gv\$resource_limit order by RESOURCE_NAME;



PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^



PROMPT RECYCLEBIN OBJECTS#:

PROMPT ^^^^^^^^^^^^^^^^^^^^



set feedback off

select count(*) "RECYCLED_OBJECTS#",sum(space)*$blksize/1024/1024 "TOTAL_SIZE_MB" from dba_recyclebin group by 1;

set feedback on

PROMPT

PROMPT [Note: Consider Purging DBA_RECYCLEBIN for better performance]





PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT FLASHBACK RESTORE POINTS:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^



select * from V\$RESTORE_POINT;





PROMPT

PROMPT ^^^^^^^^^^^^^^^



PROMPT HEALTH MONITOR:

PROMPT ^^^^^^^^^^^^^^^



select name,type,status,description,repair_script from V\$HM_RECOMMENDATION where time_detected > sysdate -1;



PROMPT ^^^^^^^^^^^^^^^^^^



PROMPT Monitored INDEXES:

PROMPT ^^^^^^^^^^^^^^^^^^



set linesize 200 pages 1000

col Index_NAME for a40

col TABLE_NAME for a40

        select io.name Index_NAME, t.name TABLE_NAME,decode(bitand(i.flags, 65536),0,'NO','YES') Monitoring,

        decode(bitand(ou.flags, 1),0,'NO','YES') USED,ou.start_monitoring,ou.end_monitoring

        from sys.obj$ io,sys.obj$ t,sys.ind$ i,sys.object_usage ou where i.obj# = ou.obj# and io.obj# = ou.obj# and t.obj# = i.bo#;



--PROMPT

--PROMPT To stop monitoring USED indexes use this command:



--prompt select 'ALTER INDEX RA.'||io.name||' NOMONITORING USAGE;' from sys.obj$ io,sys.obj$ t,sys.ind$ i,sys.object_usage ou where i.obj# = ou.obj# and io.obj# = ou.obj# and t.obj# = i.bo#

--prompt and decode(bitand(i.flags, 65536),0,'NO','YES')='YES' and decode(bitand(ou.flags, 1),0,'NO','YES')='YES' order by 1

--prompt /



PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^



PROMPT REDO LOG SWITCHES:

PROMPT ^^^^^^^^^^^^^^^^^^



set linesize 200

col day for a11

SELECT to_char(first_time,'YYYY-MON-DD') day,

to_char(sum(decode(to_char(first_time,'HH24'),'00',1,0)),'9999') "00",

to_char(sum(decode(to_char(first_time,'HH24'),'01',1,0)),'9999') "01",

to_char(sum(decode(to_char(first_time,'HH24'),'02',1,0)),'9999') "02",

to_char(sum(decode(to_char(first_time,'HH24'),'03',1,0)),'9999') "03",

to_char(sum(decode(to_char(first_time,'HH24'),'04',1,0)),'9999') "04",

to_char(sum(decode(to_char(first_time,'HH24'),'05',1,0)),'9999') "05",

to_char(sum(decode(to_char(first_time,'HH24'),'06',1,0)),'9999') "06",

to_char(sum(decode(to_char(first_time,'HH24'),'07',1,0)),'9999') "07",

to_char(sum(decode(to_char(first_time,'HH24'),'08',1,0)),'9999') "08",

to_char(sum(decode(to_char(first_time,'HH24'),'09',1,0)),'9999') "09",

to_char(sum(decode(to_char(first_time,'HH24'),'10',1,0)),'9999') "10",

to_char(sum(decode(to_char(first_time,'HH24'),'11',1,0)),'9999') "11",

to_char(sum(decode(to_char(first_time,'HH24'),'12',1,0)),'9999') "12",

to_char(sum(decode(to_char(first_time,'HH24'),'13',1,0)),'9999') "13",

to_char(sum(decode(to_char(first_time,'HH24'),'14',1,0)),'9999') "14",

to_char(sum(decode(to_char(first_time,'HH24'),'15',1,0)),'9999') "15",

to_char(sum(decode(to_char(first_time,'HH24'),'16',1,0)),'9999') "16",

to_char(sum(decode(to_char(first_time,'HH24'),'17',1,0)),'9999') "17",

to_char(sum(decode(to_char(first_time,'HH24'),'18',1,0)),'9999') "18",

to_char(sum(decode(to_char(first_time,'HH24'),'19',1,0)),'9999') "19",

to_char(sum(decode(to_char(first_time,'HH24'),'20',1,0)),'9999') "20",

to_char(sum(decode(to_char(first_time,'HH24'),'21',1,0)),'9999') "21",

to_char(sum(decode(to_char(first_time,'HH24'),'22',1,0)),'9999') "22",

to_char(sum(decode(to_char(first_time,'HH24'),'23',1,0)),'9999') "23"

from v\$log_history where first_time > sysdate-1

GROUP by to_char(first_time,'YYYY-MON-DD') order by 1 asc;





PROMPT

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



PROMPT Modified Parameters Since Instance Startup:

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



col name for a45

col VALUE for a120

col DEPRECATED for a10

select NAME,VALUE,ISDEFAULT "DEFAULT",ISDEPRECATED "DEPRECATED" from v\$parameter where ISMODIFIED = 'SYSTEM_MOD' order by 1;



PROMPT

PROMPT ^^^^^^^^^^^^



PROMPT Cred Backup:

PROMPT ^^^^^^^^^^^^



col name for a35

col "CREATE_DATE||PASS_LAST_CHANGE" for a60

select name,PASSWORD HASH,CTIME ||' || '||PTIME "CREATE_DATE||PASS_LAST_CHANGE" from user\$ where PASSWORD is not null order by 1;



spool off

exit;

EOF

)



        fi



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

# Reporting New Created Objects in the last 24Hours:

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

NEWOBJCONTRAW=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set pages 0 feedback off echo off;

select count(*) from dba_objects

where created > sysdate-1

and owner <> 'SYS';

exit;

EOF

)

NEWOBJCONT=`echo ${NEWOBJCONTRAW} | awk '{print $NF}'`

                if [ ${NEWOBJCONT} -ge ${NEWOBJCONTTHRESHOLD} ]

                 then

VALNEWOBJCONT=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set linesize 200 pages 1000

spool ${DB_HEALTHCHK_RPT} app

prompt

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt New Created objects [Last 24H] ...

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt

col owner for a30

col object_name for a30

col object_type for a19

col created for a20

select object_type,owner,object_name,to_char(created, 'DD-Mon-YYYY HH24:MI:SS') CREATED from dba_objects

where created > sysdate-1

and owner <> 'SYS'

order by owner,object_type;



spool off

exit;

EOF

)

        fi



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

# Checking AUDIT RECORDS ON THE DATABASE:

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

# Check if Checking Audit Records is ENABLED:

    case ${CHKAUDITRECORDS} in

    Y|y|YES|Yes|yes)

VAL70=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set pages 0 feedback off echo off;

SELECT (SELECT COUNT(*) FROM dba_audit_trail

where ACTION_NAME not like 'LOGO%' and ACTION_NAME not in ('SELECT','SET ROLE') and timestamp > SYSDATE-1)

+

(SELECT COUNT(*) FROM DBA_AUDIT_SESSION WHERE timestamp > SYSDATE-1 and returncode = 1017)

+

(SELECT COUNT(*) FROM dba_fga_audit_trail WHERE timestamp > SYSDATE-1)

+

(SELECT COUNT(*) FROM dba_objects where created > sysdate-1 and owner <> 'SYS') AUD_REC_COUNT FROM dual;

exit;

EOF

)

VAL80=`echo ${VAL70} | awk '{print $NF}'`

                if [ ${VAL80} -ge ${AUDITRECOTHRESHOLD} ]

                 then

VAL90=$(${ORACLE_HOME}/bin/sqlplus -S "/ as sysdba" << EOF

set linesize 200 pages 1000

spool ${LOG_DIR}/audit_records.log

col OS_USERNAME for a20

col EXTENDED_TIMESTAMP for a36

col OWNER for a25

col OBJ_NAME for a25

col OS_USERNAME for a20

col USERNAME for a25

col USERHOST for a35

col ACTION_NAME for a25

col ACTION_OWNER_OBJECT for a55

col TERMINAL for a30

col ACTION_NAME for a20

col TIMESTAMP for a21



prompt

prompt

prompt ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt Failed Login Attempts in the last 24Hours ...

prompt ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt

select to_char (EXTENDED_TIMESTAMP,'DD-MON-YYYY HH24:MI:SS') TIMESTAMP,OS_USERNAME,USERNAME,TERMINAL,USERHOST,ACTION_NAME

from DBA_AUDIT_SESSION

where returncode = 1017

and timestamp > (sysdate -1)

order by 1;



prompt

prompt

prompt ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt Audit records in the last 24Hours AUD$...

prompt ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt

select extended_timestamp,OS_USERNAME,USERNAME,USERHOST,ACTION_NAME||'  '||OWNER||' . '||OBJ_NAME ACTION_OWNER_OBJECT

from dba_audit_trail

where

ACTION_NAME not like 'LOGO%'

and ACTION_NAME not in ('SELECT','SET ROLE')

-- and USERNAME not in ('CRS_ADMIN','DBSNMP')

-- and OS_USERNAME not in ('workflow')

-- and OBJ_NAME not like '%TMP_%'

-- and OBJ_NAME not like 'WRKDETA%'

-- and OBJ_NAME not in ('PBCATTBL','SETUP','WRKIB','REMWORK')

and timestamp > SYSDATE-1 order by EXTENDED_TIMESTAMP;

prompt

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt Fine Grained Auditing Data ...

PROMPT ^^^^^^^^^^^^^^^^^^^^^^^^^^^



prompt

col sql_text for a70

col time for a36

col USERHOST for a21

col db_user for a15

select to_char(timestamp,'DD-MM-YYYY HH24:MI:SS') as time,db_user,userhost,sql_text,SQL_BIND

from dba_fga_audit_trail

where

timestamp > SYSDATE-1

-- and policy_name='PAYROLL_TABLE'

order by EXTENDED_TIMESTAMP;



spool off

exit;

EOF

)

cat ${LOG_DIR}/audit_records.log >>  ${DB_HEALTHCHK_RPT}

                fi

    ;;

    esac

mail -s "HEALTH CHECK REPORT: For Database [${DB_NAME_UPPER}] on Server [${SRV_NAME}]" ${MAIL_LIST} < ${DB_HEALTHCHK_RPT}



echo "HEALTH CHECK REPORT FOR DATABASE [${DB_NAME_UPPER}] WAS SAVED TO: ${DB_HEALTHCHK_RPT}"

        done



echo ""



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

# De-Neutralize login.sql file: [Bug Fix]

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

# If login.sql was renamed during the execution of the script revert it back to its original name:

        if [ -f ${USR_ORA_HOME}/login.sql_NeutralizedBy${SCRIPT_NAME} ]

         then

mv ${USR_ORA_HOME}/login.sql_NeutralizedBy${SCRIPT_NAME}  ${USR_ORA_HOME}/login.sql

        fi



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

# END OF SCRIPT

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

# REPORT BUGS to: mahmmoudadel@hotmail.com

# DOWNLOAD THE LATEST VERSION OF DATABASE ADMINISTRATION BUNDLE FROM:

# http://dba-tips.blogspot.com/2014/02/oracle-database-administration-scripts.html

# DISCLAIMER: THIS SCRIPT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT WITHOUT ANY WARRANTY. IT IS PROVIDED "AS IS".

oracle@test02:~>



############## Daily Archive IO details ####################



oracle@test02:~> cat /u04/MasterDB/scripts/daily_health_check/archive_IO/archive_IO.sh

#*******DR HOURLY STATUS REPORT*******

#

# Prepared by VARUN YADAV.

#

#*************************************

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

#Setting Oracle Environment Variables

#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

. /home/oracle/.bash_profile



DR_log=/u04/MasterDB/scripts/daily_health_check/archive_IO/PROD_ARCHIVE_IO.log

printf "to:abc@abc.com\n" > $DR_log

#printf "cc:abc@abc.com\n" >> $DR_log

printf "subject:  Daily Archive IO Report " >> $DR_log



sqlplus -s "/as sysdba" <<EOF >> $DR_log



set lines 200

select name,open_mode,database_role from v\$database;

set timi on



select 'Started Time = '||to_char(sysdate,'DD-MON-YYYY HH:MI:SS') from dual;



COLUMN LUN FORMAT A70

COLUMN total_io FORMAT 999999999999

set pages 1000

SELECT SUBSTR(i.name,1,7) LUN,sum(x.phyrds+x.phywrts) "Total_IO" FROM v\$filestat x,SYS.ts$ ts,v\$datafile i,SYS.file$ f WHERE i

.file# = f.file# AND ts.ts# = f.ts# AND x.file# = f.file# group by SUBSTR(i.name,1,7);

select 'End Time = '||to_char(sysdate, 'DD-MON-YYYY HH:MI:SS') from dual;



PROMPT

PROMPT

PROMPT Previous day archive logs generation

PROMPT ==================================================



select count(1),sum((BLOCKS*BLOCK_SIZE)/1024/1024/1024) "Total_archive_size_in_GB" from v\$archived_log where first_time >= trunc(sysdate) -1 and first_time <trunc(sysdate);



EOF

/usr/sbin/sendmail -t < $DR_log





oracle@test02:~>





###################### Alert Monitor #####################





oracle@test02:~> cat /u04/MasterDB/scripts/alert_log/alert_monitor.sh

. /home/oracle/.bash_profile

export SID=SMRPRODB

#export DIR=/u04/MasterDB/scripts/alert_log

export DIR=/u02/app/oracle/diag/rdbms/smrprodb/SMRPRODB/trace

touch $DIR/alert_${SMRPRODB}.hist

touch $DIR/alert.err

    cd =/u02/app/oracle/diag/rdbms/smrprodb/SMRPRODB/trace

        tail -1000  alert_SMRPRODB.log >> $DIR/alert_SMRPRODB.hist

        grep ORA- $DIR/alert_SMRPRODB.hist > $DIR/alert.err

    diff $DIR/alert.err $DIR/alert_old.err >$DIR/alert_error.err



    if [ `cat $DIR/alert_error.err|wc -l` -gt 0 ]



    then



#        mailx -s "${SID} SMRPRODB ALERT : ORA- ERRORS" varun.yadav@abc.com,core@abc.com< $DIR/alert.err

mailx -s "${SID} ALERT : ORA- ERRORS" varun.yadav@abc.com,core@abc.com< $DIR/alert.err

    fi



    mv  $DIR/alert.err $DIR/alert_old.err



    rm  $DIR/alert_error.err



    rm  $DIR/alert_${SID}.hist









oracle@test02:~>



############ Alert log check ##########





oracle@test02:~> cat /u04/MasterDB/scripts/alert_log/check_alert_log.sh

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

## check_alert_log.sh ##

##

## Author :

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

###!/bin/bash

##

#######

####### Start of configuration

#######

######## Oracle Enviorment variables ##########

##

export ORACLE_BASE=/u02/app

export ORACLE_HOME=/u02/app/oracle/diag/rdbms/prodb/PRODB/trace

export PATH=${ORACLE_HOME}/bin:${JAVA_HOME}/bin:$PATH:.:

export ORACLE_SID=PRODB

##

######## Other variables #################

##

DBA=varun.yadav@abc.com,core_oradba@abc.com

datevar=$(date)

##

#######

#######

#######

####### End of configuration

#######

#######

##

cd /u02/app/oracle/diag/rdbms/prodb/PRODB/trace

if [ -f alert_${ORACLE_SID}.log ]

then

tail -500 alert_${ORACLE_SID}.log > /u04/MasterDB/scripts/alert_log/alert_work.log

grep ORA- /u04/MasterDB/scripts/alert_log/alert_work.log >> /u04/MasterDB/scripts/alert_log/alert.err

grep Shut /u04/MasterDB/scripts/alert_log/alert_work.log >> /u04/MasterDB/scripts/alert_log/alert.err

fi

export error << `cat /u04/MasterDB/scripts/alert_log/alert.err`



if[ `cat /u04/MasterDB/scripts/alert_log/alert.err|wc -l` -gt 0 ]

then

mailx -s “${ORACLE_SID} ORACLE ALERT ERRORS $datevar” $DBA < /u04/MasterDB/scripts/alert_log/alert_work.log

fi

fi

#rm -f /u04/MasterDB/scripts/alert_log/alert.err

#rm -f /u04/MasterDB/scripts/alert_log/alert_work.log

exit



oracle@test02:~>

##################### Stats Gathers Schema ###################################





oracle@test02:~> cat /u04/MasterDB/scripts/SMRPRODB_statsgather.sh

export ORACLE_BASE=/u02/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/12.1.0/dbhome_1

export ORACLE_SID=PRODB

export PATH=$PATH:$ORACLE_HOME/bin

stats_log=/u04/MasterDB/scripts/dmenvstats.log

printf "to:varun.yadav@abc.com\n" > $stats_log

printf "cc:abc@abc.com\n" >> $stats_log

printf "subject:Production Infodba Schema stats gather details " >> $stats_log



sqlplus -s "/as sysdba" <<EOF >> $stats_log



set lines 200

PROMPT DATABASE NAME

PROMPT =================

Select name,open_mode,database_role,db_unique_name from v\$database;



PROMPT Infodba Schema stats gather details

PROMPT ==================================================

exec DBMS_Stats.Gather_Schema_Stats('INFODBA', estimate_percent => 10, degree => 3,cascade => true);

EOF

/usr/sbin/sendmail -t < $stats_log

oracle@test02:~>



oracle@test02:~> cat /u04/MasterDB/scripts/PRODB_statsgather.sh

export ORACLE_BASE=/u02/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/12.1.0/dbhome_1

export ORACLE_SID=PRODB

export PATH=$PATH:$ORACLE_HOME/bin

stats_log=/u04/MasterDB/scripts/dmenvstats.log

printf "to:varun.yadav@abc.com\n" > $stats_log

printf "cc:abc@abc.com\n" >> $stats_log

printf "subject:Production Infodba Schema stats gather details " >> $stats_log



sqlplus -s "/as sysdba" <<EOF >> $stats_log



set lines 200

PROMPT DATABASE NAME

PROMPT =================

Select name,open_mode,database_role,db_unique_name from v\$database;



PROMPT Infodba Schema stats gather details

PROMPT ==================================================

exec DBMS_Stats.Gather_Schema_Stats('INFODBA', estimate_percent => 10, degree => 3,cascade => true);

EOF

/usr/sbin/sendmail -t < $stats_log

oracle@test02:~> cat /u04/MasterDB/scripts/smr_prod_check_instance.sh

#!/bin/sh

SERVICE=ora_pmon_PRODB

#replace ‘orcl’ with your sid

DBALIST="core@abc.com";export DBALIST

if ps -ef | grep -v grep | grep $SERVICE > /dev/null

then

#echo "$SERVICE service running, everything is fine" | mailx -s "database prodb DR on `hostname` is up" $DBALIST

#echo "Alert" | mailx -s "database prodb DR on `hostname` is UP" $DBALIST

else

echo "$SERVICE is not running contact DBA " $DBALIST | mailx -s "database prodb Production database 64 on `hostname` is down" $DBALIST

#echo "Alert" | mailx -s "database prodb DR on `hostname` is down" $DBALIST

fi



oracle@test02:~>

























Oracle 11.2.0.1.0 to 11.2.0.4.0 Window Upgrade Standalone



  • Database Name : Testupgr
  • Oracle home : 
  • Listener Name : Listener11g
#######################################################################
  • Download Patchset P13390677 and unzip both file 1 and file 2.  
  • Take existing Full RMAN Backup before upgrade.
  • Oracle database Pre check 
  • Copy the following Files to New Home 11.2.0.4.0
  • Stop and delete services.
  • set oracle home and start upgrade
  • Change timezone version from 11 to 14 .
  • Post Upgrade steps.
  • Change the compatibility parameter.
######################################################################
  • Download patchset p13390677 file1 and file 2 from metalink
  • Install 11.2.0.4 binary on different home.



  • Take RMAN FULL Backup Before starting proceeding further ( Script format below if required) - 

RMAN> run

2> {
3> delete backup;
4> allocate channel d0 type disk FORMAT 'D:\varun_D\upgrades_issue\11january2019\%d_%s_U%U.bak';
5> allocate channel d1 type disk FORMAT 'D:\varun_D\upgrades_issue\11january2019\%d_%s_U%U.bak';
6> crosscheck backup;
7> crosscheck archivelog all;
8> report obsolete;
9> delete noprompt obsolete;
10> sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';
11> BACKUP AS COMPRESSED BACKUPSET INCREMENTAL LEVEL 0 tag='FULL_BACKUP_WEEKLY' DATABASE INCLUDE CURRENT CONTROLFILE FILESPERSET 1;
12> BACKUP AS COMPRESSED BACKUPSET ARCHIVELOG ALL;
13> delete noprompt archivelog all backed up 1 times to disk;
14> SQL "ALTER SYSTEM ARCHIVE LOG CURRENT " ;
15> copy current controlfile to 'D:\varun_D\upgrades_issue\11january2019\control01.bak';
16> RELEASE CHANNEL d0;
17> RELEASE CHANNEL d1;
18> }

  • stop Oracle database services using command. or using saervices.exe can be done .
C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>net stop oracleserviceTESTUPGR

Pre-checks :-

  • After Installing 11.2.0.4 , Go to 11.2.0.1 database and run :

SQL> spool pre_upgrade.log
SQL> @C:\app\varunyadav\product\11.2.0\dbhome_1\rdbms\admin\utlu112i.sql
SQL> spool off


  • Copy the following Files to New Home 11.2.0.4 :
Sql > Create pfile from spfile;
1.Spfile/Pfile/init.ora
2.orapwd
3.tnsname.ora
4.Listener.ora 

Stop Service
C:\>net stop oracleserviceTESTDB
The OracleServiceTESTDB service is stopping.
The OracleServiceTESTDB service was stopped successfully.

Delete Service using correct oradim
C:\>where oradim
C:\app\salmqure\product\11.2.0\dbhome_1\BIN\oradim.exe
C:\app\salmqure\product\12.1.0\dbhome_1\BIN\oradim.exe

C:\>C:\app\salmqure\product\11.2.0\dbhome_1\BIN\oradim.exe -delete -sid protect
Instance deleted.

C:\>C:\app\salmqure\product\12.1.0\dbhome_1\BIN\oradim.exe -new -sid protect -syspwd syspassword -startmode auto
Instance created.


set ORACLE_SID=protect
For Windows
C:\>set ORACLE_HOME=C:\app\salmqure\product\12.1.0\dbhome_1
C:\>set PATH=%ORACLE_HOME%\bin;%PATH%
C:\>set ORACLE_SID=PROTECT

For UNIX based
$export ORACLE_HOME=/u01/app/oracle/product/12.1.0/db_1
$export PATH=$ORACLE_HOME\bin:$PATH
$export ORACLE_SID=PROTECT

sql>startup upgrade
sql>spool cat_upgrd.log
@d:/oracle/11.2.0.4/dbhome_1/rdbms/admin/catupgrd.sql
spool off

sql>startup
@d:/oracle/11.2.0.4/dbhome_1/rdbms /admin/utlrp.sql
shutdown immediate;



  • Check timezone version

time zone Version 11 to 14

SQL> sho parameter compatible

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
compatible                           string      11.2.0.4.0
SQL> select * from v$timezone_file;

FILENAME                VERSION
-------------------- ----------
timezlrg_11.dat              11

SQL>  SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value
  2  FROM DATABASE_PROPERTIES
  3  WHERE PROPERTY_NAME LIKE 'DST_%'
  4  ORDER BY PROPERTY_NAME;

PROPERTY_NAME                  VALUE
------------------------------ ------------------------------------------------------------------------------------------------------------------------
DST_PRIMARY_TT_VERSION         11
DST_SECONDARY_TT_VERSION       0
DST_UPGRADE_STATE              NONE

SQL> SELECT version FROM v$timezone_file;

   VERSION
----------
        11

SQL> shut immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> exit

D:\app\varunyadav\product\11.2.4.0\dbhome_1\BIN>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.4.0 Production on Thu Apr 5 13:41:13 2018

Copyright (c) 1982, 2013, Oracle.  All rights reserved.

Connected to an idle instance.

SQL> startup upgrade
ORACLE instance started.

Total System Global Area 3390558208 bytes
Fixed Size                  2285952 bytes
Variable Size            1962937984 bytes
Database Buffers         1409286144 bytes
Redo Buffers               16048128 bytes
Database mounted.
Database opened.
SQL> set serveroutput on
SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value
  2  FROM DATABASE_PROPERTIES
  3  WHERE PROPERTY_NAME LIKE 'DST_%'
  4  ORDER BY PROPERTY_NAME;

PROPERTY_NAME
------------------------------
VALUE
--------------------------------------------------------------------------------
DST_PRIMARY_TT_VERSION
11

DST_SECONDARY_TT_VERSION
0

DST_UPGRADE_STATE
NONE


SQL> EXEC DBMS_DST.BEGIN_UPGRADE(14);
An upgrade window has been successfully started.

PL/SQL procedure successfully completed.

SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value
  2  FROM DATABASE_PROPERTIES
  3  WHERE PROPERTY_NAME LIKE 'DST_%'
  4  ORDER BY PROPERTY_NAME;

PROPERTY_NAME
------------------------------
VALUE
--------------------------------------------------------------------------------
DST_PRIMARY_TT_VERSION
14

DST_SECONDARY_TT_VERSION
11

DST_UPGRADE_STATE
UPGRADE



Post upgrade steps –
$ sqlplus “/as sysdba”
SQL> STARTUP
SQL> @?/rdbms/admin/utlu112s.sql
select comp_name,version,status from dba_registry;
select owner,count(*) from dba_objects where status != ‘VALID’ group by owner;

  • Change the compatibility parameter
Change the compatible parameter and restart the database.
—-SQL> alter system set compatible=’11.2.0.4.0' scope=spfile;
SQL> shutdown immediate;
SQL> startup;
NOTE :-
if OWB component is not upgraded properly, do the following steps...
¦Upgrade the OWB Component to the database version
1.Start SQLPlus and connect with an account having SYSDBA privileges
2.Drop the OWBSYS schema by executing the script:
SQL> @<OH>/owb/UnifiedRepos/clean_owbsys.sql 
3.Re-create the OWBSYS schema with the script:
SQL> spool <a_file_system_path>cat_owb.log
SQL> @<OH>/owb/UnifiedRepos/cat_owb.sql <tablespace_name>
#############################################################################
SQL> @D:\app\varunyadav\product\11.2.4.0\dbhome_1\owb\UnifiedRepos\clean_owbsys.sql
SQL> @D:\app\varunyadav\product\11.2.4.0\dbhome_1\owb\UnifiedRepos\cat_owb.sql

TROUBLESHOOTING

SQL> @C:\app\varunyadav\product\11.2.0.4\dbhome_1\owb\UnifiedRepos\clean_owbsys.sql
drop user owbsys cascade
*
ERROR at line 1:
ORA-04045: errors during recompilation/revalidation of MDSYS.SDO_GEOR_BDDL_TRIGGER
ORA-01031: insufficient privileges


drop user owbsys_audit cascade
*
ERROR at line 1:
ORA-04045: errors during recompilation/revalidation of MDSYS.SDO_GEOR_BDDL_TRIGGER
ORA-01031: insufficient privileges


drop role OWB_user
*
ERROR at line 1:
ORA-04045: errors during recompilation/revalidation of MDSYS.SDO_GEOR_BDDL_TRIGGER
ORA-01031: insufficient privileges


drop role OWB_DESIGNCENTER_view
*
ERROR at line 1:
ORA-04045: errors during recompilation/revalidation of MDSYS.SDO_GEOR_BDDL_TRIGGER
ORA-01031: insufficient privileges


drop role OWB$CLIENT
*
ERROR at line 1:
ORA-04045: errors during recompilation/revalidation of MDSYS.SDO_GEOR_BDDL_TRIGGER
ORA-01031: insufficient privileges


SQL> ALTER SYSTEM SET "_system_trig_enabled" = FALSE scope=both;

System altered.

SQL> @C:\app\varunyadav\product\11.2.0.4\dbhome_1\owb\UnifiedRepos\clean_owbsys.sql



Friday, 11 January 2019

Register Oracle Window 11g and 12c database listener on same hostname ERROR: ORA-12514: TNS:listener does not currently know of service requested in connect descriptor

Hi All , This blogging only for sharing knowledge. As what troubleshooting i have faced and solution i have found i m sharing the same.

11g
11g Database : TESTUPGR
Listener Name : listener11g
Service name : testupgr
Port:1522

C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>set ORACLE_SID=testupgr
C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>set ORACLE_HOME=C:\app\varunyadav\product\11.2.0\dbhome_1

12c
12c Database : TEST
Listener Name : listener 12c
Service Name : test
Port : 1521

C:\app\varunyadav\product\12.1.0\dbhome_1\BIN>set ORACLE_SID=test

C:\app\varunyadav\product\12.1.0\dbhome_1\BIN>set ORACLE_HOME=C:\app\varunyadav\product\12.1.0\dbhome_1

I have already installed oracle 12c stand alone database on window machine. listener already created.  and able to connect db remotely as well.

Actually i was upgrading 11.2.0.1.0 to 11.2.0.4.0 . 11g software and database created successfully. But during listener configuration. services of 11g database not showing when typing command.




lsnrctl status listener11g .  Instead of showing, 11g services were showing or pointing towards on  12c listener.

By default PMON process pointing towards 1521 port so 11g services showing on 12c listener.

As we have 1522 port on 11g, We have to set local_listener on 11g parameter and register the database using sql prompt.

After setting the paramater value 11g services showing on  lsnrctl status listener11g and 12c listener status earlier showing 11g services got disabled.

Please find troubleshooting steps below : 
#################################################################################


  • I have made local connection to 11g  database  and able to connect remotely. 

C:\Windows\system32>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Thu Jan 10 13:30:09 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options.

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


  • While connecting using service got error below.


C:\Windows\system32>sqlplus sys/system123@testupgr as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Thu Jan 10 13:30:39 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

ERROR:
ORA-12514: TNS:listener does not currently know of service requested in connect
descriptor

C:\Windows\system32>

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



  • While checking listener service on 11g not showing services.

C:\Windows\system32>lsnrctl status listener11g

LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 10-JAN-2019 13:30:22

Copyright (c) 1991, 2010, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY)(PORT=1522)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER11G
Version                   TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Production
Start Date                10-JAN-2019 13:30:02
Uptime                    0 days 0 hr. 0 min. 19 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   C:\app\varunyadav\product\11.2.0\dbhome_1\network\admin\listener.ora
Listener Log File         c:\app\varunyadav\diag\tnslsnr\VARUNY\listener11g\alert\log.xml
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=VARUNY)(PORT=1522)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1522ipc)))
Services Summary...
Service "CLRExtProc" has 1 instance(s).
  Instance "CLRExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully



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


  • On 12c it is showing 11g services , As by default PMON service point towards 1521 port.


C:\app\varunyadav\product\12.1.0\dbhome_1\BIN>lsnrctl status listener

LSNRCTL for 64-bit Windows: Version 12.1.0.2.0 - Production on 10-JAN-2019 19:03:15

Copyright (c) 1991, 2014, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY)(PORT=1521)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR for 64-bit Windows: Version 12.1.0.2.0 - Production
Start Date                10-JAN-2019 19:01:06
Uptime                    0 days 0 hr. 2 min. 9 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   C:\app\varunyadav\product\12.1.0\dbhome_1\network\admin\listener.ora
Listener Log File         C:\app\varunyadav\diag\tnslsnr\VARUNY\listener\alert\log.xml
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=2762VARUNY1198L.mind.motherson.com)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1521ipc)))
Services Summary...
Service "CLRExtProc" has 1 instance(s).
  Instance "CLRExtProc", status UNKNOWN, has 1 handler(s) for this service...
Service "pdb1" has 1 instance(s).
  Instance "test", status READY, has 1 handler(s) for this service...
Service "pdb2" has 1 instance(s).
  Instance "test", status READY, has 1 handler(s) for this service...
Service "test" has 1 instance(s).
  Instance "test", status READY, has 1 handler(s) for this service...
Service "testXDB" has 1 instance(s).
  Instance "test", status READY, has 1 handler(s) for this service...
Service "testupgr" has 1 instance(s).
  Instance "testupgr", status READY, has 1 handler(s) for this service...
Service "testupgrXDB" has 1 instance(s).
  Instance "testupgr", status READY, has 1 handler(s) for this service...
The command completed successfully

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


  • We need to set local listener on 11g and register database later.


C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Thu Jan 10 19:06:06 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> sho parameter listener

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
listener_networks                    string
local_listener                       string
remote_listener                      string
SQL> alter system set local_listener='(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY)(PORT=1522))' scope=both;

System altered.


SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

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

  • Stop and start the listener on 11g

C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>lsnrctl stop listener11g

LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 10-JAN-2019 19:07:41

Copyright (c) 1991, 2010, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY1198L)(PORT=1522)))
The command completed successfully

C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>lsnrctl start listener11g

LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 10-JAN-2019 19:07:45

Copyright (c) 1991, 2010, Oracle.  All rights reserved.

Starting tnslsnr: please wait...

TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Production
System parameter file is C:\app\varunyadav\product\11.2.0\dbhome_1\network\admin\listener.ora
Log messages written to c:\app\varunyadav\diag\tnslsnr\VARUNY\listener11g\alert\log.xml
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=VARUNY)(PORT=1522)))
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1522ipc)))

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY)(PORT=1522)))
STATUS of the LISTENER
------------------------
Alias                     listener11g
Version                   TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Production
Start Date                10-JAN-2019 19:07:48
Uptime                    0 days 0 hr. 0 min. 3 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   C:\app\varunyadav\product\11.2.0\dbhome_1\network\admin\listener.ora
Listener Log File         c:\app\varunyadav\diag\tnslsnr\VARUNY\listener11g\alert\log.xml
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=2762VARUNY1198L.mind.motherson.com)(PORT=1522)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1522ipc)))
Services Summary...
Service "CLRExtProc" has 1 instance(s).
  Instance "CLRExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully
##########################################################################

  •  As you can set above still services are not showing up , So we have to register database as well.

C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Thu Jan 10 19:07:54 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> alter system register;

System altered.

SQL> sho parameter listener

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
listener_networks                    string
local_listener                       string      (ADDRESS=(PROTOCOL=TCP)(HOST=2
                                                 762VARUNY1198L)(PORT=1522))
remote_listener                      string
SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

###############################################################################
  • Check the listener services 
C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>lsnrctl status listener11g

LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 10-JAN-2019 19:08:34

Copyright (c) 1991, 2010, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=VARUNY)(PORT=1522)))
STATUS of the LISTENER
------------------------
Alias                     listener11g
Version                   TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Production
Start Date                10-JAN-2019 19:07:48
Uptime                    0 days 0 hr. 0 min. 48 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   C:\app\varunyadav\product\11.2.0\dbhome_1\network\admin\listener.ora
Listener Log File         c:\app\varunyadav\diag\tnslsnr\VARUNY\listener11g\alert\log.xml
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=2762VARUNY1198L.mind.motherson.com)(PORT=1522)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1522ipc)))
Services Summary...
Service "CLRExtProc" has 1 instance(s).
  Instance "CLRExtProc", status UNKNOWN, has 1 handler(s) for this service...
Service "testupgr" has 1 instance(s).
  Instance "testupgr", status READY, has 1 handler(s) for this service...
Service "testupgrXDB" has 1 instance(s).
  Instance "testupgr", status READY, has 1 handler(s) for this service...
The command completed successfully

C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>

#################################################################################
  • Able to connect 11g database service remotely using service entry
C:\app\varunyadav\product\11.2.0\dbhome_1\BIN>sqlplus sys/system123@testupgr as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Thu Jan 10 19:08:13 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options


################### Thank you ####################################################