广

oracle数据库

  • MYSQL
  • MSSQL
  • Redis
  • MongoDB
  • oracle数据库
  • 数据管理

    监控Oracle数据库的常用shell脚本

    2018-04-05 20:18:30 次阅读 稿源:互联网
    广告
    全网推广平台,软文发布

      前言

      这篇文章介绍了DBA每天在监控Oracle数据库方面的职责,讲述了如何通过shell脚本来完成这些重复的监控工作。本文首先回顾了一些DBA常用的Unix命令,以及解释了如何通过Unix Cron来定时执行DBA脚本。同时文章还介绍了8个重要的脚本来监控Oracle数据库:

       检查实例的可用性
     
       检查监听器的可用性

       检查alert日志文件中的错误信息
     
       在存放log文件的地方满以前清空旧的log文件

       分析table和index以获得更好的性能

       检查表空间的使用情况

       找出无效的对象

       监控用户和事务

      DBA需要的Unix基本知识

      基本的UNIX命令

      以下是一些常用的Unix命令:

       ps--显示进程
       grep--搜索文件中的某种文本模式
       mailx--读取或者发送mail
       cat--连接文件或者显示它们
       cut--选择显示的列
       awk--模式匹配语言
       df--显示剩余的磁盘空间

      以下是DBA如何使用这些命令的一些例子:

      显示服务器上的可用实例:

    $ ps -ef | grep smon
    oracle 21832 1 0 Feb 24 ? 19:05 ora_smon_oradb1
    oracle 898 1 0 Feb 15 ? 0:00 ora_smon_oradb2
    dliu 25199 19038 0 10:48:57 pts/6 0:00 grep smon
    oracle 27798 1 0 05:43:54 ? 0:00 ora_smon_oradb3
    oracle 28781 1 0 Mar 03 ? 0:01 ora_smon_oradb4、

      显示服务器上的可用监听器:

    $ ps -ef | grep listener | grep -v grep
    (译者注:grep命令应该加上-i参数,即grep -i listener,该参数的作用是忽略大小写,因为有些时候listener是大写的,这时就会看不到结果)
    oracle 23879 1 0 Feb 24 ? 33:36 /8.1.7/bin/tnslsnr listener_db1 -inherit
    oracle 27939 1 0 05:44:02 ? 0:00 /8.1.7/bin/tnslsnr listener_db2 -inherit
    oracle 23536 1 0 Feb 12 ? 4:19 /8.1.7/bin/tnslsnr listener_db3 -inherit
    oracle 28891 1 0 Mar 03 ? 0:01 /8.1.7/bin/tnslsnr listener_db4 -inherit

      查看Oracle存档目录的文件系统使用情况

    $ df -k | grep oraarch
    /dev/vx/dsk/proddg/oraarch 71123968 4754872 65850768 7% /u09/oraarch

      统计alter.log文件中的行数:

    $ cat alert.log | wc -l
    2984 

      列出alert.log文件中的全部Oracle错误信息:

    $ grep ORA- alert.log
    ORA-00600: internal error code, arguments: [kcrrrfswda.1], [], [], [], [], []
    ORA-00600: internal error code, arguments: [1881], [25860496], [25857716], []

      CRONTAB基本

      一个crontab文件中包含有六个字段:

      分钟 0-59

      小时 0-23

      月中的第几天 1-31

      月份 1 - 12

      星期几 0 - 6, with 0 = Sunday

      Unix命令或者Shell脚本

      要编辑一个crontab文件,输入:

      Crontab -e

      要查看一个crontab文件,输入:

    Crontab -l
    0 4 * * 5 /dba/admin/analyze_table.ksh
    30 3 * * 3,6 /dba/admin/hotbackup.ksh /dev/null 2>&1

      在上面的例子中,第一行显示了一个分析表的脚本在每个星期5的4:00am运行。第二行显示了一个执行热备份的脚本在每个周三和周六的3:00a.m.运行。

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告
    广告