在Linux系統(tǒng)上同時(shí)監(jiān)控多個(gè)Oracle數(shù)據(jù)庫(kù)表空間的方法
一,設(shè)計(jì)背景
由于所在公司ORACLE數(shù)據(jù)庫(kù)較多,傳統(tǒng)人工監(jiān)控表空間的方式較耗時(shí),且無(wú)法記錄歷史表空間數(shù)據(jù),無(wú)法判斷每日表空間增長(zhǎng)量,在沒有g(shù)ridcontrol/cloudcontrol軟件的情況下,筆者設(shè)計(jì)如下表空間監(jiān)控方案,大家也可以根據(jù)自己的實(shí)際情況對(duì)下面的方案進(jìn)行修改。
二,設(shè)計(jì)思路
通過(guò)dblink將來(lái)查詢到的表空間數(shù)據(jù)集中匯總到一張表里通過(guò)crontab跑定時(shí)任務(wù)從各臺(tái)服務(wù)器獲取表空間使用情況信息。
三,具體實(shí)施步驟
1.所在oracle數(shù)據(jù)庫(kù)ip地址信息(下面為舉例說(shuō)明具體情況要根據(jù)所在環(huán)境設(shè)置)
2.在tbsmonitor主機(jī)上創(chuàng)建tbsmonitor表空間
create tablespace tbsmonitor datafile '/opt/u01/app/oradata/tbsmonitor/tsmonitor.dbf' size 50M autoextend on;
3.在tbsmonitor和database1/database2/database3上建立tbsmonitor用戶用來(lái)做表空間監(jiān)控。
create user tsmonitor identified by I11m8cb default tablespace tsmonitor;
4.為了tbsmonitor用戶賦權(quán)用來(lái)查找表空間使用情況。
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服務(wù)器的話可以略過(guò)
10.1.21.2 database1 10.1.21.3 database2 10.1.21.4 database3
7.在tbsmonitor主機(jī)設(shè)置dblink,這樣就能通過(guò)dblink從被監(jiān)控服務(wù)器遠(yuǎn)程抽取表空間信息。
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表,表空間統(tǒng)計(jì)數(shù)據(jù)將插入這張表。
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中運(yùn)行每日0點(diǎn)1分更新數(shù)據(jù)庫(kù)表空間信息的腳本tbsmonitor.sh(我根據(jù)業(yè)務(wù)需要每日統(tǒng)計(jì)一次,大家也可以通過(guò)業(yè)務(wù)要求修改統(tǒng)計(jì)頻率)
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.創(chuàng)建插入腳本(拿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.查看表空間使用占比可以使用如下語(yǔ)句(如果要查看某臺(tái)機(jī)器可以帶上條件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表空間增長(zhǎng)的情況)
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'
相關(guān)文章
Oracle?CDB管理實(shí)現(xiàn)多租戶管理功能
這篇文章主要介紹了Oracle?CDB管理實(shí)現(xiàn)多租戶管理功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用oracle具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-12-12oracle?指定類型和指定位數(shù)創(chuàng)建序列號(hào)的代碼詳解
這篇文章主要介紹了oracle?指定類型和指定位數(shù)創(chuàng)建序列號(hào),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05Oracle按身份證號(hào)得到省市、性別、年齡的示例代碼
這篇文章主要介紹了Oracle按身份證號(hào)得到省市、性別、年齡,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06Oracle數(shù)據(jù)庫(kù)批量變更字段類型的實(shí)現(xiàn)步驟
我有個(gè)項(xiàng)目使用Oracle數(shù)據(jù)庫(kù),運(yùn)行幾年后數(shù)據(jù)量較大,需要對(duì)數(shù)據(jù)庫(kù)做一次優(yōu)化,其中有些字段類型類型需要調(diào)整,這里分享一下實(shí)現(xiàn)步驟,感興趣的朋友可以參考下2024-02-02ORACLE分區(qū)表轉(zhuǎn)換在線重定義DBMS_REDEFINITION
這篇文章主要為大家介紹了ORACLE分區(qū)表轉(zhuǎn)換在線重定義DBMS_REDEFINITION表,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Oracle 實(shí)現(xiàn) 一個(gè)關(guān)鍵字 匹配多個(gè) 字段的方法
這篇文章主要介紹了Oracle 實(shí)現(xiàn) 一個(gè)關(guān)鍵字 匹配多個(gè) 字段的方法,本文給大家提供兩個(gè)方案,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-05-05