加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在Linux系统上同时监控多个Oracle数据库表空间的方法

发布时间:2020-12-12 17:02:38 所属栏目:百科 来源:网络整理
导读:一,设计背景 由于所在公司ORACLE数据库较多,传统人工监控表空间的方式较耗时,且无法记录历史表空间数据,无法判断每日表空间增长量,在没有gridcontrol/cloudcontrol软件的情况下,笔者设计如下表空间监控方案,大家也可以根据自己的实际情况对下面的方案

一,设计背景


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

二,设计思路

2016114172632984.png (664×403)

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

三,具体实施步骤


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

2016114172702293.png (580×282)

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

代码如下:

create tablespace tbsmonitor datafile '/opt/u01/app/oradata/tbsmonitor/tsmonitor.dbf' size 50M autoextend on;


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(我根据业务需要每日统计一次,大家也可以通过业务要求修改统计频率)

1 0 * * * /opt/u01/app/oracle/tbsmonitor.sh

>/opt/u01/app/oracle/tbsmonitor.sh sqlplus sys/I11m08cb as sysdba <> /opt/u01/app/oracle/tbsmonitor.log 2>&1 @/opt/u01/app/oracle/tbsmonitor/ tbsmonitor.sql; @/opt/u01/app/oracle/tbsmonitor/database1.sql; @/opt/u01/app/oracle/tbsmonitor/database2.sql; @/opt/u01/app/oracle/tbsmonitor/database3.sql; EOF echo >> /opt/u01/app/oracle/ tbsmonitor.log

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读