多台ORACLE数据库表空间监控方案

  • A+
所属分类:Oracle
又拍云upyun

一,设计背景


 

由于所在公司ORACLE数据库较多,传统人工监控表空间的方式较耗时,且无法记录历史表空间数据,无法判断每日表空间增长量,在没有gridcontrol/cloudcontrol软件的情况下,笔者设计如下表空间监控方案,大家也可以根据自己的实际情况对下面的方案进行修改。

二,设计思路


 

oracle

通过dblink将来查询到的表空间数据集中汇总到一张表里通过crontab跑定时任务从各台服务器获取表空间使用情况信息。

三,具体实施步骤


 

1.所在oracle数据库ip地址信息(下面为举例说明具体情况要根据所在环境设置)

hostname 备注 ipaddress tnsname instancename
tbsmonitor 监控数据库 10.1.21.1 tbsmonitor tbsmonitor
database1 被监控数据库 10.1.21.2 database1 database1
database2 被监控数据库 10.1.21.3 database2 database2
database3 被监控数据库 10.1.21.4 database3 database3

2.在tbsmonitor主机上创建tbsmonitor表空间

3.在tbsmonitor和database1/database2/database3上建立tbsmonitor用户用来做表空间监控。

4.为了tbsmonitor用户赋权用来查找表空间使用情况。

5.在tbsmonitor上建立database1/ database2/ database3的tnsnames.ora连接,在tnsnames.ora文件中加入

6.修改/etc/hosts文件,如果有dns服务器的话可以略过

7.在tbsmonitor主机设置dblink,这样就能通过dblink从被监控服务器远程抽取表空间信息。

8.建立tbsmonitor表,表空间统计数据将插入这张表。

9. 在crontab中运行每日0点1分更新数据库表空间信息的脚本tbsmonitor.sh(我根据业务需要每日统计一次,大家也可以通过业务要求修改统计频率)

 

11.创建插入脚本(拿database1举例,以此类推)

Sql脚本如下

12.查看表空间使用占比可以使用如下语句(如果要查看某台机器可以带上条件where ipaddress=’xxxx’ and instance=’xxxxx’ and to_char(time,’yyyy-mm-dd’)=’xxxx-xx-xx’)

13.查看每日增量可以使用如下脚本。(下面显示的是4-8日10.1.21.2表空间增长的情况)

四,改进方向


 

本方案适合有一定oracle基础的读者,今后的改进方向是通过python进行开发对dba所需要的表空间数据数据文件数据等信息进行图形化的展示,并实现添加删除数据文件,表空间大小超过阈值告警等功能。

本文原创,转载请注明出处、作者

如有错误,欢迎指正

邮箱15980219172@139.com

weinxin
微信公众号
扫一扫关注运维生存时间公众号,获取最新技术文章~

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:1   其中:访客  1   博主  0

    • yanjj_dev 0

      赞!期待下一版