麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Oracle > 正文

在Linux系統上同時監控多個Oracle數據庫表空間的方法

2024-08-29 13:58:49
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了在Linux系統上同時監控多個Oracle數據庫表空間的方法,文中給出了shell腳本以及統計數據的錄入寫法,需要的朋友可以參考下
 

一,設計背景
 
由于所在公司ORACLE數據庫較多,傳統人工監控表空間的方式較耗時,且無法記錄歷史表空間數據,無法判斷每日表空間增長量,在沒有gridcontrol/cloudcontrol軟件的情況下,筆者設計如下表空間監控方案,大家也可以根據自己的實際情況對下面的方案進行修改。
二,設計思路

在Linux系統上同時監控多個Oracle數據庫表空間的方法

通過dblink將來查詢到的表空間數據集中匯總到一張表里通過crontab跑定時任務從各臺服務器獲取表空間使用情況信息。
三,具體實施步驟
 
1.所在oracle數據庫ip地址信息(下面為舉例說明具體情況要根據所在環境設置)

在Linux系統上同時監控多個Oracle數據庫表空間的方法

2.在tbsmonitor主機上創建tbsmonitor表空間

 

復制代碼代碼如下:

 

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

 


3.在tbsmonitor和database1/database2/database3上建立tbsmonitor用戶用來做表空間監控。

 

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 database110.1.21.3 database210.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:[email protected]_SID= tbsmonitorORACLE_BASE=/opt/u01/appORACLE_HOME=/opt/u01/app/oraclePATH=$ORACLE_HOME/bin:$PATH;export PATHexport ORACLE_SID ORACLE_BASE ORACLE_HOMEdate>>/opt/u01/app/oracle/tbsmonitor.shsqlplus 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;EOFecho >> /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 timeFROM dba_data_files@TO_DATABASE1 df,(SELECT tablespace_name,file_id,SUM(BYTES) BYTES,MAX(BYTES) maxbytesFROM dba_free_space@TO_DATABASE1GROUP BY tablespace_name, file_id) freeWHERE df.tablespace_name = free.tablespace_name(+)AND df.file_id = free.file_id(+)GROUP BY df.tablespace_nameORDER 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') bwhere a.tablespace_name=b.tablespace_name and a.IPADDRESS=b.IPADDRESS order by increase descselect * from tbsmonitor. tbsmonitor where ipaddress='10.1.21.2' and to_char(time,'yyyy-mm-dd')='2016-01-08'


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: h色在线观看 | 看一级毛片 | 国产1区2区3区中文字幕 | 成码无人av片在线观看网站 | 久久免费视频7 | 久久人人爽人人爽人人片av高清 | 91精品国产777在线观看 | 一级国产航空美女毛片内谢 | 一区二区三区欧美在线 | 高清国产午夜精品久久久久久 | 九一传媒在线观看 | 九九热免费在线观看 | 午夜噜噜噜| av懂色 | 久久久久国产一区二区三区不卡 | 偿还的影视高清在线观看 | 精品一区二区三区欧美 | va视频在线观看 | 午夜男人在线观看 | 精品一区二区久久久久久按摩 | 黄色av片在线观看 | 斗罗破苍穹在线观看免费完整观看 | 国产精品免费麻豆入口 | 精品久久www | 视频一区二区在线观看 | 国产在线观看91精品 | 国内毛片视频 | 欧美一级免费高清 | 永久免费在线观看av | a网在线| 日韩黄色av网站 | 久久草草影视免费网 | www.99av| 性高潮一级片 | 久久毛片| 成人短视频在线播放 | 91亚洲精品一区二区福利 | 视频在线中文字幕 | 91看片免费版 | 精品成人国产在线观看男人呻吟 | 萌白酱福利视频在线网站 |