Python巡检Oracle表空间并邮件告警

 

  最近,自学了Python基础,突发奇想,把以前通过shell自定义通过nagios实现Oracle表空间以及ASM以及备份的脚本改进下,首先感叹的是Python脚本看上去确实挺好的,效率还不错。

这是初步版本,姑且定义为v0.1吧,目前具备的功能很简单——得到超过阀值的表空间信息。

 

 

 

#############################################
# python3.5 #
# Any questions contact me ! #
# 2424623044@qq.com #
#############################################
#/usr/bin/python3 #coding=utf-8 import cx_Oracle jdbc=["system/redhat@10.1.14.67/ora.my.com",] #后面增加完整的数据库JDBC即可 for d in jdbc: con = cx_Oracle.Connection(d) cur=con.cursor() c = cur.execute("""select tablespace_name, max_gb, used_gb, round(100 * used_gb / max_gb) "pct_used(%)" from (select a.tablespace_name tablespace_name, round((a.bytes_alloc - nvl(b.bytes_free, 0)) / power(2, 30), 2) used_gb, round(a.maxbytes / power(2, 30), 2) max_gb from (select f.tablespace_name, sum(f.bytes) bytes_alloc, sum(decode(f.autoextensible, 'YES', f.maxbytes, 'NO', f.bytes)) maxbytes from dba_data_files f group by tablespace_name) a, (select f.tablespace_name, sum(f.bytes) bytes_free from dba_free_space f group by tablespace_name) b where a.tablespace_name = b.tablespace_name(+) union all select h.tablespace_name tablespace_name, round(sum(nvl(p.bytes_used, 0)) / power(2, 30), 2) used_gb, round(sum(decode(f.autoextensible, 'YES', f.maxbytes, 'NO', f.bytes)) / power(2, 30), 2) max_gb from v$temp_space_header h, v$temp_extent_pool p, dba_temp_files f where p.file_id(+) = h.file_id and p.tablespace_name(+) = h.tablespace_name and f.file_id = h.file_id and f.tablespace_name = h.tablespace_name group by h.tablespace_name)""") for x in c: if x[3]>60: #阀值为60,这里是为了测试 print ("The IP:%s TBS %s usages is %s"%(d.split('@')[1].split('/')[0],x[1],x[3])) cur.close() con.close()

#结果:Warning:IP:10.1.14.67 TBS 3 usages is overtarget 99

  

 

遗留问题:

1.未封装,数据库JDBC信息透明

2.未多线程化,脚本相对比较低级

3.未加入邮件告警功能

4.未设置异常处理

 

后续继续优化。

 

转载于:https://www.cnblogs.com/joewan/p/6802168.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python语言是一种非常适合网络编程的语言,并且具有很多网络编程库。要批量探测IP地址的存活性,我们可以使用Python的socket库。此外,要发送电子邮件,我们可以使用Python内置的smtplib模块。如果需要发送纯文本邮件,用SMTP邮件协议即可。如果需要发送HTML邮件,则需要使用MIME邮件协议。 批量探测IP地址存活性的方法是:使用ping命令,向目标主机发送ICMP封包,如果目标主机收到ICMP封包,它会回送一个ICMP封包,表示自己的存活状态。通过判断返回数据包中的状态码和延迟等指标,就可以判断目标主机的存活状态。 下面是一个简单的Python代码段,可以实现批量探测IP地址存活性和发送邮件告警: ```python #导入必要的模块 import subprocess import smtplib #定义目标IP地址列表 targets = ['192.168.1.1','192.168.1.2','192.168.1.3'] #遍历目标地址列表 for target in targets: #执行ping命令并获取结果 response = subprocess.Popen(['ping', '-c', '1', target], stdout=subprocess.PIPE).communicate()[0] #提取ping结果中的状态码 response_status = int(response.split('\n')[-3].split()[3]) #判断状态码并发送邮件告警 if response_status == 0: #如果存活,就不发送邮件 pass else: #如果不存活,就发送邮件 server = smtplib.SMTP('smtp.gmail.com', 587) server.starttls() server.login('youremail@gmail.com', 'yourpassword') message = 'Subject: IP Address Alert\n\n' + target + ' is not responding to ping.' server.sendmail('youremail@gmail.com', 'recipient@example.com', message) server.quit() ``` 在以上代码中,`targets`是要探测的IP地址的列表。通过遍历列表中的每个IP地址,使用`subprocess.Popen`函数执行ping命令并获取响应结果。判断响应结果中包含的状态码,如果为0,表示IP地址存活;如果为其他值,就发送邮件告警。要发送邮件,需要使用SMTP协议连接到email服务器,并调用`server.login`和`server.sendmail`函数。如果成功,就会发送一封电子邮件给指定的收件人。 总之,Python语言在批量探测IP地址存活性和发送邮件告警方面非常灵活。以上代码只是一个简单的例子,可以根据需要进行修改和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值