Shell脚本实现硬盘空间和表空间的使用情况统计并邮件通知

 更新时间:2014年12月21日 14:54:13   投稿:junjie  
这篇文章主要介绍了Shell脚本实现硬盘空间和表空间的使用情况统计并邮件通知,其中表空间是指oracle数据库里的表空间,需要的朋友可以参考下

复制代码 代码如下:

#/bin/bash
#该脚本用于统计硬盘空间和表空间的使用情况,并邮件发出
#初始化环境变量
source /home/oracle/.bash_profile
#获得本机ip
ip=`/sbin/ifconfig eth0 | grep Bcast | cut -d : -f 2 | cut -d " " -f 1`
#切换到本脚本目录
cd /home/oracle/shell/
#删除之前该脚本产生的日志文件
rm -rf $ip.txt
#统计硬盘空间
echo -e "您好!
    $ip统计信息如下:\n\n" >> $ip.txt
echo "硬盘空间统计:" >> $ip.txt
/bin/df -Th >> $ip.txt
#统计表空间
echo -e "\n\n\n表空间统计:" >> $ip.txt
sqlplus -s scott/tiger << EOF >> $ip.txt
set feed off
set lines 400
set pages 900
col 表空间名 for a20
select x.tablespace_name 表空间名,已用,已分配,已用占已分配的比例,空闲的已分配空间,最大可用空间,已分配占最大可用比例,可自动扩展的空间
  from (select TABLESPACE_NAME,round(sum(BYTES) / 1024 / 1024 / 1024, 9) 已分配,
               round(sum(MAXBYTES - BYTES) / 1024 / 1024 / 1024,2) 可自动扩展的空间,
               round(sum(MAXBYTES) / 1024 / 1024 / 1024) 最大可用空间,
               to_char(round(sum(BYTES) / sum(MAXBYTES) * 100, 2), '990.99') || '%' 已分配占最大可用比例
          from dba_data_files
         group by TABLESPACE_NAME) x,
       (select a.tablespace_name,
               round(a.bytes / 1024 / 1024 / 1024, 9) 已用,
               round(b.bytes / 1024 / 1024 / 1024, 9) 空闲的已分配空间,
               to_char(round(a.bytes / (a.bytes + b.bytes) * 100, 2),
                       '990.99') || '%' 已用占已分配的比例
          from sys.sm\$ts_used a, sys.sm\$ts_free b
         where a.tablespace_name = b.tablespace_name) y
 where x.tablespace_name = y.tablespace_name
 order by 1;
exit
EOF
#把统计结果邮件发出
mutt -s "$ip统计信息" -- zhangwz@xx.net < $ip.txt

 
加到操作系统的定时任务中:

每周五的15:30执行此脚本

复制代码 代码如下:

[oracle@ ~]$ crontab -l
30 15 * * 5  /home/oracle/shell/weekcheck.sh

相关文章

  • linux sudo密码输入时显示星号的操作方法

    linux sudo密码输入时显示星号的操作方法

    在输入linux sudo密码的时候终端是不显示任何东西的,我们不知道我们按下的密码到底输入进去了没有,如果可以像在网站上登录账号密码的时候显示星号多好,下面小编给大家介绍下linux sudo密码输入时显示星号的操作方法
    2018-01-01
  • linux 网卡配置详解及实例

    linux 网卡配置详解及实例

    这篇文章主要介绍了linux 网卡配置详解及实例的相关资料,需要的朋友可以参考下
    2017-05-05
  • 一个简单的转换输出的shell脚本代码

    一个简单的转换输出的shell脚本代码

    一个简单的转换输出的shell脚本,学习shell脚本的朋友可以看下实现方法
    2013-02-02
  • 利用Shell解析处理XML的方法汇总

    利用Shell解析处理XML的方法汇总

    这篇文章主要给大家总结介绍了关于利用Shell解析处理XML的方法,分别介绍了关于xmlint、xpath和xml2三种工具的使用,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-10-10
  • linux查看目录的四种方法(ls只显示目录)

    linux查看目录的四种方法(ls只显示目录)

    linux如何只列出目录?下面介绍4种方法列出当前路径下的目录,大家参考使用吧
    2014-01-01
  • Linux服务器硬件运行状态及故障邮件提醒的监控脚本分享

    Linux服务器硬件运行状态及故障邮件提醒的监控脚本分享

    这篇文章主要介绍了Linux服务器硬件运行状态及故障邮件提醒的监控脚本分享,能够测试CPU和内存的占用状况以及HTTP端的异常,需要的朋友可以参考下
    2016-03-03
  • 如何查看Linux提供的Shell解析器

    如何查看Linux提供的Shell解析器

    这篇文章主要介绍了查看Linux提供的Shell解析器的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • Linux 打包压缩命令详解

    Linux 打包压缩命令详解

    在Linux系统中,有多种命令可以用于打包和压缩文件,这些命令可以帮助用户将多个文件或目录打包成一个文件,并可以选择不同的压缩算法来减小文件大小,下面给大家介绍Linux 打包压缩命令详解,感兴趣的朋友一起看看吧
    2023-09-09
  • 一个简单的linux命令 cat

    一个简单的linux命令 cat

    这篇文章主要介绍了一个简单的linux命令cat,cat命令用来显示文件内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • linux 中的ls命令参数详解及ls命令的使用实例

    linux 中的ls命令参数详解及ls命令的使用实例

    这篇文章主要介绍了linux 中的ls命令参数详解及ls命令的使用实例,需要的朋友可以参考下
    2017-08-08

最新评论