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

Oracle
Excel VBA连接并操作Oracle
Oracle 外连接实现代码
oracle 存储过程和函数例子
Oracle 数据库操作类
ORACLE 分区表的设计
Oracle 用户权限管理方法
Oracle In和exists not in和not exists的比较分析
利用windows任务计划实现oracle的定期备份
ORACLE11g随RHEL5系统自动启动与关闭的设置方法
在oracle 数据库查询的select 查询字段中关联其他表的方法
plsql和tsql常用函数比对
plsql与tsql的语法不同
ASP.NET调用oracle存储过程实现快速分页
执行drop表操作后数据库无法起动
分析Oracle有时会用索引来查找数据的原因
数据从MySQL迁移到 Oracle的注意事项
快速理解Oracle归档模式的命令及参数
在Oracle里加快SQL执行的三种方法
几条常见的数据库分页 SQL 语句
Oracle9I OCP认证过程

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 53 ::
收藏到网摘: 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