一,设计背景
由于所在公司ORACLE数据库较多,传统人工监控表空间的方式较耗时,且无法记录历史表空间数据,无法判断每日表空间增长量,在没有gridcontrol/cloudcontrol软件的情况下,笔者设计如下表空间监控方案,大家也可以根据自己的实际情况对下面的方案进行修改。
二,设计思路
通过dblink将来查询到的表空间数据集中汇总到一张表里通过crontab跑定时任务从各台服务器获取表空间使用情况信息。
三,具体实施步骤
1.所在oracle数据库ip地址信息(下面为举例说明具体情况要根据所在环境设置)
2.在tbsmonitor主机上创建tbsmonitor表空间
create tablespace tbsmonitor datafile '/opt/u01/app/oradata/tbsmonitor/tsmonitor.dbf' size 50M autoextend on;
create user tsmonitor identified by I11m8cb default tablespace tsmonitor;
4.为了tbsmonitor用户赋权用来查找表空间使用情况。
grant resource to tbsmonitor; grant create session to tbsmonitor; grant create table to tbsmonitor; grant select on dba_data_files to tbsmonitor; grant select on dba_free_space to tbsmonitor;
5.在tbsmonitor上建立database1/ database2/ database3的tnsnames.ora连接,在tnsnames.ora文件中加入
DATABASE1 = (DESCRIPTION= (ADDRESS=(PROTOCOL=TCP)(HOST=10.1.21.1)(PORT=1521)) (CONNECT_DATA=(SID= database1))) DATABASE2 = (DESCRIPTION= (ADDRESS=(PROTOCOL=TCP)(HOST=10.1.21.2)(PORT=1521)) (CONNECT_DATA=(SID= database2))) DATABASE3 = (DESCRIPTION= (ADDRESS=(PROTOCOL=TCP)(HOST=10.1.21.3)(PORT=1521)) (CONNECT_DATA=(SID= database3)))
6.修改/etc/hosts文件,如果有dns服务器的话可以略过
10.1.21.2 database1 10.1.21.3 database2 10.1.21.4 database3
7.在tbsmonitor主机设置dblink,这样就能通过dblink从被监控服务器远程抽取表空间信息。
create database link TO_DATABASE1 connect to TSMONITOR identified by I11m08cb using 'DATABASE1'; create database link TO_DATABASE2 connect to TSMONITOR identified by I11m08cb using 'DATABASE2'; create database link TO_DATABASE3 connect to TSMONITOR identified by I11m08cb using 'DATABASE3';
8.建立tbsmonitor表,表空间统计数据将插入这张表。
create table tbsmonitor.tbsmonitor ( ipaddress VARCHAR2(200), instancename VARCHAR2(200), tablespace_name VARCHAR2(200), datafile_count NUMBER, size_mb NUMBER, free_mb NUMBER, used_mb NUMBER, maxfree NUMBER, pct_used NUMBER, pct_free NUMBER, time DATE ) tablespace tbsmonitor;
9. 在crontab中运行每日0点1分更新数据库表空间信息的脚本tbsmonitor.sh(我根据业务需要每日统计一次,大家也可以通过业务要求修改统计频率)
1 0 * * * /opt/u01/app/oracle/tbsmonitor.sh
#!/bin/bash #FileName: tbsmonitor.sh #CreateDate:2016-01-1 #version:1.0 #Discription:take the basic information to insert into the table tbs_usage # Author:FUZHOU HOT #Email:15980219172@139.com ORACLE_SID= tbsmonitor ORACLE_BASE=/opt/u01/app ORACLE_HOME=/opt/u01/app/oracle PATH=$ORACLE_HOME/bin:$PATH;export PATH export ORACLE_SID ORACLE_BASE ORACLE_HOME date>>/opt/u01/app/oracle/tbsmonitor.sh sqlplus sys/I11m08cb as sysdba <<EOF >> /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举例,以此类推)
/opt/u01/app/oracle/tbsmonitor/database1.sql; /opt/u01/app/oracle/tbsmonitor/database2.sql; /opt/u01/app/oracle/tbsmonitor/database3.sql; /opt/u01/app/oracle/tbsmonitor/ tbsmonitor.sql;
Sql脚本如下
insert into tsmonitor.tbsmonitor SELECT utl_inaddr.get_host_address('DATABASE1') ipaddress, (select instance_name from v$instance) instancename, df.tablespace_name, COUNT(*) datafile_count, ROUND(SUM(df.BYTES) / 1048576) size_mb, ROUND(SUM(free.BYTES) / 1048576, 2) free_mb, ROUND(SUM(df.BYTES) / 1048576 - SUM(free.BYTES) / 1048576, 2) used_mb, ROUND(MAX(free.maxbytes) / 1048576, 2) maxfree, 100 - ROUND(100.0 * SUM(free.BYTES) / SUM(df.BYTES), 2) pct_used, ROUND(100.0 * SUM(free.BYTES) / SUM(df.BYTES), 2) pct_free,sysdate time FROM dba_data_files@TO_DATABASE1 df, (SELECT tablespace_name, file_id, SUM(BYTES) BYTES, MAX(BYTES) maxbytes FROM dba_free_space@TO_DATABASE1 GROUP BY tablespace_name, file_id) free WHERE df.tablespace_name = free.tablespace_name(+) AND df.file_id = free.file_id(+) GROUP BY df.tablespace_name ORDER BY 6;
12.查看表空间使用占比可以使用如下语句(如果要查看某台机器可以带上条件where ipaddress='xxxx' and instance='xxxxx' and to_char(time,'yyyy-mm-dd')='xxxx-xx-xx')
SELECT IPADDRESS , Instancename, tablespace_name, datafile_count, size_mb "表空间大小(M)", used_mb "已使用空间(M)", TO_CHAR(ROUND((used_mb) / size_mb * 100, 2), '990.99') "使用比", free_mb "空闲空间(M)" FROM tbsmonitor. tbsmonitor order by "使用比" desc
13.查看每日增量可以使用如下脚本。(下面显示的是4-8日10.1.21.2表空间增长的情况)
select a.tablespace_name,(b.used_mb-a.used_mb) increase,a.ipaddress from (select * from tsmonitor.tbs_usage where to_char(time,'yyyy-mm-dd')='2016-01-04') a, (select * from tsmonitor.tbs_usage where to_char(time,'yyyy-mm-dd')='2016-01-08') b where a.tablespace_name=b.tablespace_name and a.IPADDRESS=b.IPADDRESS order by increase desc select * from tbsmonitor. tbsmonitor where ipaddress='10.1.21.2' and to_char(time,'yyyy-mm-dd')='2016-01-08'
本文向大家介绍监控Linux系统节点和服务性能的方法,包括了监控Linux系统节点和服务性能的方法的使用技巧和注意事项,需要的朋友参考一下 1、获取信息 2、筛选信息 3、整理数据 例如用Excel整理内存使用情况,这里把获取的时间和内存信息放在Excel内部,并把内存列用Excel分列,用时间和使用的内存大小列可以制作出一张内存使用趋势图;同理也可以制作CPU、cached及各个微服务的CP
本文向大家介绍查找oracle数据库表中是否存在系统关键字的方法,包括了查找oracle数据库表中是否存在系统关键字的方法的使用技巧和注意事项,需要的朋友参考一下 今天在工程中遇到“ORA-01747: user.table.column, table.column 或列说明无效”的报错情况,查了一下是由于数据库列名起的不好引起的,名字用到了数据库的关键字。 ID可以忽略
本文向大家介绍Oracle表空间数据文件移动的方法,包括了Oracle表空间数据文件移动的方法的使用技巧和注意事项,需要的朋友参考一下 实现把用户表空间中的数据文件从某一个路径移动到另一个路径 一、针对可offline的非系统表空间 本例移动oracle的案例表空间(EXAMPLE表空间),将其从 D:\ORADATA\ORCL\ 移动到 D:\ORACLE\ORADATA\ 1.查看要改变的表空
本文向大家介绍innodb系统表空间维护方法,包括了innodb系统表空间维护方法的使用技巧和注意事项,需要的朋友参考一下 环境说明: 有一个在运行中的mysql环境,由于之前的配置文件设置的过于简单(没有配置innodb_data_file_path变更);造成现在系统表空间已经满了 如果innodb_data_file_path之前没有设置那么它会采用默认值:innodb_data_file_
本文向大家介绍在Oracle数据库中同时更新两张表的简单方法,包括了在Oracle数据库中同时更新两张表的简单方法的使用技巧和注意事项,需要的朋友参考一下 以前只会写一些简单的updaet语句,比如updae table set c1='XXX' 之类的 今天遇到一个数据订正的问题,项目背景如下,有个表A,有两个字段a1,a2还有一个关联表B,其中也有两个字段,b1和b2。其中a2和b2是关联的,
问题内容: 当尝试在支持bash的最新Windows 10版本上使用Oracle JDK的Linux版本时,无论何时尝试调用二进制文件,我都遇到提示挂起的问题。 键入甚至挂起之类的简单内容,我也必须终止该过程以恢复控制。 有人在工作吗? 问题答案: 我想澄清一下,截至2016年12月9日,您肯定可以在Windows 10的Ubuntu Bash上安装Java 8,并且@Karl Horton是正确
我有一个用例,其中我想将我的spring boot API度量发布到Datadog 我已将以下依赖项添加到pom中。 主要应用类 我还在应用程序中添加了所有必需。 我可以看到指标被发布到两个数据狗 但这是更改名称为两个云手表 我的问题是,如何仅更改Datadog的默认指标名称或保持两者的单词不同。
事务处理 索引