售前咨询
技术支持
渠道合作

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

一,设计背景


 

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

二,设计思路


 

通过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表空间增长的情况)

文章转载来自:ttlsa.com

相关文章