在linux/aix下用邮件对表空间报警

2024-04-24 16:38

本文主要是介绍在linux/aix下用邮件对表空间报警,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自己写了一个表空间报警程序。针对自动扩展的数据文件,有一个file limitation的问题,如8k的数据库,数据文件的限制是32g,脚本针对这个问题也可以报警。

1.setup service.txt -->将server 上需要监控的service 名写入一个文件:
$more service.txt
db1
db2
db3

2.在每个数据库创建用户oper并授予以下权限
grant select on SYS.SM$TS_AVAIL to oper;
grant select on SYS.SM$TS_USED to oper;
grant select on SM$TS_FREE to oper;
grant select on v_$database to oper;
grant select on v_$parameter to oper;
grant select on dba_data_files to oper;
grant select on dba_extents to oper;
grant select on dba_free_space to oper;
grant connect,resource to oper;

3.用oper创建以下存储过程:
CREATE OR REPLACE PROCEDURE Space_Monitor
IS
var_dbname v$database.NAME%TYPE;
var_blocksize v$parameter.VALUE%TYPE;
var_filelimit NUMBER;
CURSOR cur_tabalert IS
SELECT v1.file_name,v1.autoextensible,num1 total_space,
num3 free_space,
num1-num3 "USED_SPACE"
FROM
(SELECT file_name,file_id,autoextensible,SUM(bytes) num1 FROM DBA_DATA_FILES GROUP BY file_name,file_id,autoextensible) v1,
  (SELECT file_id,SUM(BYTES) num3 FROM DBA_FREE_SPACE GROUP BY file_id) v3
  WHERE v1.file_id=v3.file_id(+);

CURSOR cur_tabspacealt IS
SELECT TABLESPACE_NAME,TOTAL,USED,FREE,USED_CENT,FREE_CENT FROM (
SELECT A.TABLESPACE_NAME,TRUNC(A.BYTES/1024/1024) TOTAL,TRUNC(B.BYTES/1024/1024) USED, TRUNC(C.BYTES/1024/1024) FREE,
ROUND((B.BYTES*100)/A.BYTES,2)  USED_CENT,ROUND((C.BYTES*100)/A.BYTES,2) FREE_CENT
FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C
WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND A.TABLESPACE_NAME=C.TABLESPACE_NAME) ;

BEGIN
SELECT NAME INTO var_dbname FROM v$database;
SELECT VALUE INTO var_blocksize FROM v$parameter WHERE NAME='db_block_size';
SELECT POWER(2,22)*var_blocksize INTO var_filelimit  FROM dual;
FOR rec_tabalert IN cur_tabalert
    LOOP
   IF rec_tabalert.autoextensible='YES'
         THEN
   IF rec_tabalert.used_space/var_filelimit >0.9 THEN
       DBMS_OUTPUT.PUT_LINE('File: '||rec_tabalert.file_name||' in database  '||var_dbname||' is autoextend,  '||' Now Used% is >90%');
          END IF;
     END IF;
END LOOP;
  FOR rec_tabspacealt IN cur_tabspacealt
    LOOP
   IF rec_tabspacealt.FREE_CENT<5 THEN
    DBMS_OUTPUT.PUT_LINE('Free space of Tablespace  '||rec_tabspacealt.tablespace_name||' in  database '||var_dbname||' is  <5%');
    END IF;
    END LOOP;
END;
/

4.运行以下脚本:
¥more space_monitor.ksh
. /etc/profile
. $HOME/.profile

USER="user@126.com 139xxxxxx@139.com" --利用139邮箱的短信功能进行实时报警

for i in `cat /u80/scripts/service.txt | awk -F: ' {print $1}'`
do
sqlplus oper/oper@$i << EOF
set serveroutput on
set echo off
set term off
set verify off
set feedback off
spool /u80/scripts/space_monitor_$i
exec space_monitor;
spool off
EOF

#checking
#echo "FILE: space_monitor_${i}.lst"
if (( `cat /u80/scripts/space_monitor_${i}.lst|wc -l` > 2 ))
then
  sed -e '1d;$d' /u80/scripts/space_monitor_${i}.lst|mail -s "${i} space is not enough" "${USER}"
fi
done

这篇关于在linux/aix下用邮件对表空间报警的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/932268

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与