当前位置: 首页 > 图文教程 > 数据库 > Oracle > 检测Oracle的可用性和表空间容量

Oracle
oracle sys_connect_by_path 函数 结果集连接
oracle join on 数据过滤问题
Oracle 当前用户下所有表的记录总数
oracle 树查询 语句
oracle 触发器 实现出入库
Oracle 函数大全
oracle 删除重复数据
ORACLE 最大连接数的问题
oracle 层次化查询(行政区划三级级联)
oracle 查询表名以及表的列名
Oracle 数据显示 横表转纵表
oracle 服务启动,关闭脚本(windows系统下)
ORCLE 表中列的修改
oracle 数据库连接分析
Oracle 实现类似SQL Server中自增字段的一个办法
Oracle 常用的SQL语句
Oracle 数组的学习 小知识也要积累,养成好的学习态度
Oracle 日期的一些简单使用
Oracle 数据库连接查询SQL语句
Oracle DBA常用语句

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 54 ::
收藏到网摘: n/a

很多人也许并不了解,检测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
  [email protected],userid2,[email protected]
  #
  # 检测关键的段没有达到最大限度
  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