如何检测Oracle的可用性和表空间容量

日期: 2008-06-15 来源:TechTarget中国

  很多人也许并不了解,检测Oracle的可用性所需要的命令比简单的ping或者ps -ef | grep 等Oracle的命令要多得多。有观点认为它需要一个使用SQL*Net 来验证监听器已经开启并运行的测试访问Oracle——这是用户经常用到的访问。通过实际地登录到实际环境中,你可以确认这个实例环境可以接受登录的,如果你只是做了以上的检测的话,你如何才能知道是否登录没有被接受,只是因为需要等待文档日志?
 
  除了Oracle的激活和可用性之外,我们还需要进行检测以确保它可以用,这样我们还可以检测表空间的容量。
 
  检测的脚本:
 
  ◆假设所有的Oracle环境都已经搭建起来了
 
  ◆假设所有的扩展都已经达到了最大的限度
 
  ◆假设左右的表空间都缺乏运行的空闲空间
 
  下面的脚本可以在你想要的任何时候通过crontab 来中断。另外,如果上面的例外情况出现了的话,您还可以就这个脚本写信或者电子邮件给支持人员获得帮助。
 
  如果您有什么其他的测试,这个脚本可以让您轻松地进行修改以加以利用。我使用这个Monitororcl 脚本作为模板并且在末尾添加了功能。
 
  按crontab来调用query_oracle_instances.sh 脚本:
 







#!/bin/ksh
. /u01/home/oracle/.profile
/u01/app/oracle/admin/monitororcl 
’cat /u01/app/oracle/admin/Get_Oracle_Instance_List’
exit 


  Get_Oracle_Instance_List 脚本如下:
 







instance_name1 tnsname1 sys_password_for_this_instance
instance_name2 tnsname2 sys_password_for_this_instance
instance_name3 tnsname3 sys_password_for_this_instance 


  下面是MONITORORCL脚本:
 
 




#!/bin/ksh
  #script : Rick Stehno
  # script will monitor to see if Oracle is up
  while [ “$1” != “” ]
  do
  ORACLE_INSTANCE=$1
  ORACLE_TNS=$2
  USR_ID=sys
  USR_PASS=$3
  # echo “Instance: [$ORACLE_INSTANCE]”
  # echo “TNS [$ORACLE_TNS]”
  # echo “PASS: [$USR_PASS]”
  LOGFIL=/u01/app/oracle/admin/monitordev1.out
  NOTIFY_LIST=userid1@mobilephone.com,userid2,userid3@pagercompany.com
  #
  # 检测关键的段没有达到最大限度
  sqlplus -s <$LOGFIL 2>/dev/null
  $USR_ID/$USR_PASS@$ORACLE_TNS
  set pages 0
  select distinct ’YES’ from dba_segments
  where extents >= (max_extents-5) and segment_name not like ’1.%’;
  EOF1
  grep -i ’^ORA-’ $LOGFIL >/dev/null
  if [ $? -eq 0 ]
  then
  echo “$0 failed: check $ORACLE_INSTANCE for problems” | /bin/mailx –
s “${ORACLE_INSTANCE} : Script failed” $NOTIFY_LIST
  exit 1
  fi
  MAXEXTENTS_REACHED=`awk ’{ print $1 }’ $LOGFIL`
  if [ “$MAXEXTENTS_REACHED” = “YES” ]
  then
  echo “$0 failed: $ORACLE_INSTANCE max extents reached” | /bin/mailx –
s “${ORACLE_INSTANCE} : max extents reached” $NOTIFY_LIST
  exit 1
  fi
  #
  # 检测是否能分配下一个段
  sqlplus -s <$LOGFIL 2>/dev/null
  $USR_ID/$USR_PASS@$ORACLE_TNS
  set pages 0
  select distinct ’YES’ from dba_segments ds
  where next_extent >
  (select max(bytes) from dba_free_space
  where tablespace_name = ds.tablespace_name);
  EOF2
  grep -i ’^ORA-’ $LOGFIL >/dev/null
  if [ $? -eq 0 ]
  then
  echo “$0 failed: check $ORACLE_INSTANCE for problems” | /bin/mailx –
s “${ORACLE_INSTANCE} : Script failed” $NOTIFY_LIST
  exit 1
  fi
  POSSIBLE_NEXTEXT_FAIL=`awk ’{print $1 }’ $LOGFIL`
  if [ “$POSSIBLE_NEXTEXT_FAIL” = “YES” ]
  then
  echo “$0 failed: $ORACLE_INSTANCE cannot extend segment” | /bin/mailx –
s “${ORACLE_INSTANCE} : max extents reached” $NOTIFY_LIST
  exit 1
  fi
  shift 3
  # echo “shift done”
  done
  echo “Successful completion of $0” `date`
  exit 0 

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

相关推荐