SNMPv3

  • SNMPv3在路由器端的配置

这个我都没配置过,还得现学现卖
这个链接说的是SNMPv3的基本配置

这个链接说的是SNMPv3的view命令,用于管理员可以看到哪些层级的内容

1) 配置

snmp-server group READONLY v3 priv read VIEWSTD access 98
snmp-server view VIEWSTD iso included
snmp-server community galileo RO 98
snmp-server user <user> READONLY v3 auth sha <password> priv aes 128 <key>

上面的命令的意思是,snmp-server view VIEWSTD iso included是创建一个view, 这个view里只能看iso级和iso级以下的(include),创建了一个group叫READONLY, 版本v3,权限是读,VIEWSTD是和刚刚的view设置绑定, access 98是调用名字为98的ACL做访问控制。最后是创建一个v3独有的user,user有名字,也有认证用的password,也有加密用的password,把它绑到READONLY组

2) 注意snmp-server user 命令打完之后,在running config里是看不到的,用以下命令看

router1#sho snmp user

User name: pysnmp
Engine ID: 8000000903001C6A7AAF5768
storage-type: nonvolatile active
Authentication Protocol: SHA
Privacy Protocol: AES128
Group-name: READONLY
  • snmp_helper.snmp_get_oid_v3(a_device, snmp_user, oid=the_oid)

1) 变化一
去除了community的赋值,取而代之的是username, auth_key, encrypt_key. 并创建snmp_user元组

2) 变化二

他跟普通的v2版本的snmp_get_oid的最大的不同就是,中间多了一个叫user的参数,也就是刚刚在路由器上的最后一条命令创造的那个user

3) 变化三

a_device 在赋值的时候,以往是a_device = (ip_addr, commu, port), 现在是a_device = (ip_addr, port), 减少了中间的commu

4) 总体的一个代码是这样的

import snmp_helper

'''
router1#sho snmp user User name: pysnmp
Engine ID: 8000000903001C6A7AAF5768
storage-type: nonvolatile active
Authentication Protocol: SHA
Privacy Protocol: AES128
Group-name: READONLY
''' OID = '1.3.6.1.2.1.1.5.0' ip_addr = '184.105.247.70'
port = 161 snmp_user = 'pysnmp'
auth_key = 'galileo1'
encrypt_key = 'galileo1' a_user = (snmp_user, auth_key, encrypt_key) #组成user元组
a_device = (ip_addr, port) #组成device元组 snmp_data = snmp_helper.snmp_get_oid_v3(a_device, a_user, OID)
output = snmp_helper.snmp_extract(snmp_data) print output
  • 利用snmp获取interface相关数据

通过思科的工具查到和interface description相关的OID是‘1.3.6.1.2.1.2.2.1.2’,再通过snmpwalk命令到具体的设备上去查具体的端口信息

(applied_python)[-class3]$ cat snmp_walk_interface_descrp.txt
(applied_python)[- class3]$ snmpwalk -Os -c galileo -v 1 184.105.247.70 1.3.6.1.2.1.2.2.1.2
ifDescr.1 = STRING: FastEthernet0
ifDescr.2 = STRING: FastEthernet1
ifDescr.3 = STRING: FastEthernet2
ifDescr.4 = STRING: FastEthernet3
ifDescr.5 = STRING: FastEthernet4
ifDescr.6 = STRING: Null0
ifDescr.7 = STRING: Vlan1
ifDescr.11 = STRING: Vlan127
ifDescr.13 = STRING: Vlan157
(applied_python)[class3]$ snmpwalk -Os -c galileo -v 1 184.105.247.70 1.3.6.1.2.1.2.2.1.2.5
ifDescr.5 = STRING: FastEthernet4
(applied_python)[class3]$
  • for循环一次读取多个OID
#! /usr/bin/env python
import snmp_helper snmp_oids = (
('sysName', '1.3.6.1.2.1.1.5.0', None),
('sysUptime', '1.3.6.1.2.1.1.3.0', None),
('ifDescr_fa4', '1.3.6.1.2.1.2.2.1.2.5', None),
('ifInOctets_fa4', '1.3.6.1.2.1.2.2.1.10.5', True),
('ifInUcastPkts_fa4', '1.3.6.1.2.1.2.2.1.11.5', True),
('ifOutOctets_fa4', '1.3.6.1.2.1.2.2.1.16.5', True),
('ifOutUcastPkts_fa4', '1.3.6.1.2.1.2.2.1.17.5', True),
) ip_addr = '184.105.247.70'
port = 161 snmp_user = 'pysnmp'
auth_key = 'galileo1'
encrypt_key = 'galileo1' a_user = (snmp_user, auth_key, encrypt_key)
a_router = (ip_addr, port) for desc, each_oid, is_count in snmp_oids:
snmp_data = snmp_helper.snmp_get_oid_v3(a_router, a_user, oid=each_oid)
output = snmp_helper.snmp_extract(snmp_data)
print "%s %s" % (desc, output)

注意上面这段代码中的for循环中的这个 is_count,虽然他不发挥什么作用,我们在for中并不引用它,但是它也必须在for a,b,c in snmp_oids中出现,因为snmp_oid这个tuple的每个元素,都是三个元素组成的小tuple,如果把is_count去掉,会出现“ValueError: too many values to unpack”

  • 每隔一段时间运行一下上面那个for循环
#! /usr/bin/env python

import snmp_helper
import sched, time
from datetime import datetime snmp_oids = (
('sysName', '1.3.6.1.2.1.1.5.0', None),
('sysUptime', '1.3.6.1.2.1.1.3.0', None),
('ifDescr_fa4', '1.3.6.1.2.1.2.2.1.2.5', None),
('ifInOctets_fa4', '1.3.6.1.2.1.2.2.1.10.5', True),
('ifInUcastPkts_fa4', '1.3.6.1.2.1.2.2.1.11.5', True),
('ifOutOctets_fa4', '1.3.6.1.2.1.2.2.1.16.5', True),
('ifOutUcastPkts_fa4', '1.3.6.1.2.1.2.2.1.17.5', True),
) ip_addr = '184.105.247.70'
port = 161 snmp_user = 'pysnmp'
auth_key = 'galileo1'
encrypt_key = 'galileo1' a_user = (snmp_user, auth_key, encrypt_key)
a_router = (ip_addr, port) #s = sched.scheduler(time.time, time.sleep) def loop_the_oids(snmp_oids):
for desc, each_oid, is_count in snmp_oids:
snmp_data = snmp_helper.snmp_get_oid_v3(a_router, a_user, oid=each_oid)
output = snmp_helper.snmp_extract(snmp_data)
print "%s %s" % (desc, output) def print_current_time():
print datetime.now() for time_range in range(1,13):
print "time %d" % (time_range*10)
loop_the_oids(snmp_oids)
time.sleep(10)

本来是想用 sched来打印时间戳的,但是后来觉得用time.sleep和print一个累加的数字就可以实现下一步要用的横坐标了

Graph from SNMP data

我觉得这有点重复造轮子了,因为这个完全可以通过Cacti实现,而且Cacti实现的又特别好

  • pygal

pip install pygal即可

1) 初始化一个object,line_chart = pygal.Line()
2) 初始化横坐标 line_chart.x_labels = [‘0’, ‘10’, ‘20’, ‘40’]
3) 初始化一条数据折线
fa4_in_packets = [] 一个数组,这个数组在视频里Kirk是直接手写的,但是也可以从上一个实验的结果里提取,这也是这次的练习作业,还是有点难度
line_chart.add(‘InPackets’, fa4_in_packets)
4) 保存为svg格式的图片
line_chart.render_to_file(‘test.svg’)
svg格式的图片需要用浏览器打开

Sending Email

  • smtplib

python自带的一个库,使用的方式很简单,代码在最后

  • from email.mime.text import MIMEText

这个MIMEText是个什么呢,Wikipedia的解释如下
Multipurpose Internet Mail Extensions (MIME) is an Internet standard that extends the format of email to support: Text in character sets other than ASCII. Non-text attachments: audio, video, images, application programs etc.

  • 代码部分

这个password要注意,这个是在网易邮箱设置里,找到SMTP相关那一栏,点进去勾选IMAP/SMTP 和 POP3/SMTP的时候,会让你设置一个单独的密码,网易把这个码称为邮箱客户端授权码,在第三方客户端(也就是我们今天的脚本)中发邮件的时候,用这个码代替原来的163邮箱的密码

import smtplib

from email.mime.text import MIMEText

recipient1 = "balabala@163.com"

mail_host1 = "smtp.163.com"
mail_password1 = "*****"
mail_sender1 = "balabala@163.com" def send_email(recipient, subject, message, mail_sender, mail_host, mail_password):
try:
smtp_conn = smtplib.SMTP()
smtp_conn.connect(mail_host)
smtp_conn.login(mail_sender, mail_password)
print "conn created" message = MIMEText(message)
message['To'] = recipient
message['Subject'] = subject
message['From'] = mail_sender
smtp_conn.sendmail(mail_sender, recipient, message.as_string())
smtp_conn.close()
print "Your message has been sent"
return True
except Exception, e:
return False
print "oops something wrong" send_email(recipient1, "Test", "sent by script", mail_sender1, mail_host1, mail_password1)

SNMPv3/pygal制图/smtplib发邮件的更多相关文章

  1. python之smtplib发邮件

    第一版: 认证发信,不支持附件 #!/usr/bin/env python # --------------------------------------- # author : Geng Jie ...

  2. Python smtplib发邮件

    常用邮箱SMTP.POP3域名及其端口号 发送普通文本内容的邮件 import smtplib from email.header import Header from email.mime.text ...

  3. python 利用 smtplib发邮件

    import smtplib from email.mime.text import MIMEText title = "request build error" content ...

  4. 【Python】 发邮件用 smtplib & email

    smtplib & email ■ 概述 发邮件主要用到smtplib以及email模块.stmplib用于邮箱和服务器间的连接,发送的步骤.email模块主要用于处理编码,邮件内容等等.主要 ...

  5. Python自动发邮件——smtplib和email库和yagmail库

    ''' 一.先导入smtplib模块 导入MIMEText库用来做纯文本的邮件模板 二.发邮件几个相关的参数,每个邮箱的发件服务器不一样,以163为例子百度搜索服务器是 smtp.163.com 三. ...

  6. EDM营销算法:python自动批量发邮件

    EDM营销:全称Email Direct Marketing,即电子邮件营销.企业可以通过使用EDM软件向目标客户发送EDM邮件,建立同目标顾客的沟通渠道,向其直接传达相关信息,用来促进销售.EDM软 ...

  7. python发邮件遇到的端口号问题

    在学习使用python发邮件的过程中, 遇到了一个问题:由于测试的时候使用的是QQ邮箱,要求必须使用SSL/TLS加密,所以有了下面的代码, from email.mime.text import M ...

  8. python 发邮件 utf-8

    import smtplib from operator import itemgetter, attrgetter from email.mime.text import MIMEText from ...

  9. 使用python发邮件

    使用python发邮件 网上有很多发邮件的例子,本人在网上找了一份,稍加修改后使用 上源码 # encoding=utf-8 from email.mime.image import MIMEImag ...

随机推荐

  1. 快速入门系列--NOSQL--05Redis也木有那么“高富帅”

    由于工作慢慢从原来的少量用户的企业内部应用慢慢转化为了大量用户的企业内部应用或者直接转为了线上高并发应用,因而也渐渐的开始使用memcached.Redis等缓存服务器,为了便于自身的学习和记忆,特此 ...

  2. Android线程机制——AsyncTask

    对于Android为什么要使用多线程,因为从Android4.0之后,谷歌规定了网络操作不允许放在主线程中执行,由此就有了多线程的机制,有个JAVA学习经验的朋友一定知道多线程指的是什么,简单来讲就是 ...

  3. 【目录】微软Infer.NET机器学习组件文章目录

    本博客所有文章分类的总目录链接:http://www.cnblogs.com/asxinyu/p/4288836.html 1.微软Infer.NET机器学习组件目录 1. Infer.NET连载(一 ...

  4. php手册总结(一)

    一:自动加载 __autoload(): 注意: 1:spl_autoload_register() 提供了一种更加灵活的方式来实现类的自动加载.因此,不再建议使用 __autoload() 函数,在 ...

  5. HTML5移动Web开发(九)——优化浏览器视口宽度设置

    每个移动设备都有自己默认的视口宽度,如果你不显示的设置它的值,在渲染页面的时候你可能会得不到你想要的效果.比如,如果不设置iPhone的视口宽度,它将会按照980像素的宽度渲染页面,如果你的页面设计不 ...

  6. 增强学习(五)----- 时间差分学习(Q learning, Sarsa learning)

    接下来我们回顾一下动态规划算法(DP)和蒙特卡罗方法(MC)的特点,对于动态规划算法有如下特性: 需要环境模型,即状态转移概率\(P_{sa}\) 状态值函数的估计是自举的(bootstrapping ...

  7. Web 开发精华文章集锦(jQuery、HTML5、CSS3)【系列二十七】

    <Web 前端开发精华文章推荐>2014年第6期(总第27期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...

  8. Linux脚本,关闭服务器的所有tomcat并且重新启动

    echo '开始查找tomcat进程' ID=`ps -fx | grep tomcat | awk '{print $1}'` echo $ID echo "开始结束tomcat进程&qu ...

  9. Azure Redis Cache (3) 创建和使用P级别的Redis Cache

    <Windows Azure Platform 系列文章目录> 在笔者之前的文档里面已经说明了,Azure Redis Cache分为三个不同的级别: - 基本,Basic,不包含SLA ...

  10. 精品资源:40个实用的 PSD 贴纸模板《下篇》

    贴纸经常被网页设计师用于为标注网站中的不同元素,以此吸引访客的注意.此外,使用贴纸也使网站更具吸引力.虽然设计者可以使用 Photoshop 制作贴纸,但他们也可以利用从互联网上下载现成的模板.这些模 ...