监控并记录Oracle数据库空间增长的简单方法
来源:互联网 发布:禁止软件创建快捷方式 编辑:程序博客网 时间:2024/04/29 15:46
1.跟踪数据库空间增长
(SELECT SUM(ROUND(bytes_used/(1024*1024),2) + ROUND(bytes_free/(1024*1024),2)) MB_ALLOC
FROM V$temp_space_header, dba_temp_files
WHERE V$temp_space_header.file_id (+) = dba_temp_files.file_id
UNION
SELECT SUM(BYTES)/(1024*1024) MB_ALLOC FROM dba_data_files);
2.下面例子除了undo和temp表空间外,将其他表空间的的使用情况记录每周插入db_spaec_hist表,以便查询:
Create the table for database size history create table db_space_hist (
timestamp date,
total_space number(8),
used_space number(8),
free_space number(8),
pct_inuse number(5,2),
num_db_files number(5)
);
Create the procedure db_space_history CREATE OR REPLACE PROCEDURE db_space_history AS
BEGIN
INSERT INTO db_space_hist
SELECT SYSDATE, total_space,
total_space-NVL(free_space,0) used_space,
NVL(free_space,0) free_space,
((total_space - NVL(free_space,0)) / total_space)*100 pct_inuse,
num_db_files
FROM ( SELECT SUM(bytes)/1024/1024 free_space
FROM sys.DBA_FREE_SPACE WHERE tablespace_name NOT LIKE '%UNDO%') FREE,
( SELECT SUM(bytes)/1024/1024 total_space,
COUNT(*) num_db_files
FROM sys.DBA_DATA_FILES WHERE tablespace_name NOT LIKE '%UNDO%') FULL;
COMMIT;
END;
/
Create the job that runs once in a week DECLARE
X NUMBER;
BEGIN
SYS.DBMS_JOB.SUBMIT
(
job => X
,what => 'SYS.DB_SPACE_HISTORY;'
,next_date => TO_DATE('22/02/2008 19:40:28','dd/mm/yyyy hh24:mi:ss')
,INTERVAL => 'TRUNC(SYSDATE+7)'
,no_parse => FALSE
);
END;
3.做周期性监控
select * from db_space_hist order by timestamp desc;
4.查询结果(每月数据库的增长情况),统计的出发条件为createion_time.
SELECT TO_CHAR(creation_time, 'RRRR Month') "Month", round(SUM(bytes)/1024/1024/1024) "Growth in GBytes"
FROM sys.v_$datafile
WHERE creation_time > SYSDATE-365
GROUP BY TO_CHAR(creation_time, 'RRRR Month');
Month Growth in GBytes
-------------- ----------------
2008 December 1331
2008 November 779
2008 October 447
2009 April 797
2009 August 344
2009 February 505
2009 January 443
2009 July 358
2009 June 650
2009 March 452
2009 May 1787
2009 October 255
2009 September 158
- 监控并记录Oracle数据库空间增长的简单方法
- 简单的跟踪数据库增长的方法
- 关于oracle数据库表空间自动增长
- PL/SQL oracle 跨数据库复制记录的简单方法
- mongodb数据库collection的增长的监控
- 怎么监控oracle数据库表和表空间的现状
- oracle 数据库主键自动增长方法
- oracle 数据库主键自动增长方法
- 数据库的简单监控
- Oracle数据库删除重复记录的方法
- Oracle数据库删除重复记录的方法
- oracle 数据库对象增长记录查询对比语句
- Oracle数据库的字段自动增长
- Oracle数据库ID自动增长的触发器
- ORACLE正确删除归档并回收空间的方法
- ORACLE正确删除归档并回收空间的方法
- ORACLE正确删除归档并回收空间的方法
- Oracle插入数据并获取自增长序列ID方法
- NSURLConnection
- 狼与羊的思考
- 日语原版书《SQL server2016 教科书》学习笔记 第七章 ch03
- android5.0蓝牙框架分析
- 六台Debian主机安装搭建Cloudera Manager 5和CDH5(版本5.9.0)大数据集群
- 监控并记录Oracle数据库空间增长的简单方法
- lucene 基于索引的查询
- git 忽略无关文件
- Spring 学习默认参数注解解析:
- Weblogic 学习(一)
- 支持键盘上下按键
- Struts2
- android 安装和卸载apk
- 在Ubuntu server 14.04上安装caffe+ATLAS+cuda8.0+opencv2.4.8+python2.7+hdf5