イーサネット インターフェイスの統計情報をポーリングする最良の方法は、SNMP を使用することです...
Linux を使用しているようです... もしそうなら、これらのオプションをロードしてください... を/etc/defaults/snmpdsnmpd
にインストールした後snmpd
(の行が次のようになっていることを確認してください):SNMPDOPTS
SNMPDOPTS='-Lsd -Lf /dev/null -u snmp -I -smux,usmConf,iquery,dlmod,diskio,lmSensors,hr_network,snmpEngine,system_mib,at,interface,ifTable,ipAddressTable,ifXTable,ip,cpu,tcpTable,udpTable,ipSystemStatsTable,ip,snmp_mib,tcp,icmp,udp,proc,memory,snmpNotifyTable,inetNetToMediaTable,ipSystemStatsTable,disk -Lsd -p /var/run/snmpd.pid'
また、ro コミュニティをpublic
「注 1 を参照」に変更し、リスニング インターフェイスを/etc/snmp/snmpd.conf
(ループバック上にない場合) に設定する必要がある場合もあります...
機能する があると仮定するとsnmpd
、この時点で、これを使用して問題のインターフェイスについてポーリングifHCInBytes
し、ifHCOutBytes
注 2を参照できます...
poll_bytes.py :
from SNMP import v2Manager
import time
def poll_eth0(manager=None):
# NOTE: 2nd arg to get_index should be a valid ifName value
in_bytes = manager.get_index('ifHCInOctets', 'eth0')
out_bytes = manager.get_index('ifHCOutOctets', 'eth0')
return (time.time(), int(in_bytes), int(out_bytes))
# Prep an SNMP manager object...
mgr = v2Manager('localhost')
mgr.index('ifName')
stats = list()
# Insert condition below, instead of True...
while True:
stats.append(poll_eth0(mgr))
print poll_eth0(mgr)
time.sleep(5)
SNMP.py
:
from subprocess import Popen, PIPE
import re
class v2Manager(object):
def __init__(self, addr='127.0.0.1', community='public'):
self.addr = addr
self.community = community
self._index = dict()
def bulkwalk(self, oid='ifName'):
cmd = 'snmpbulkwalk -v 2c -Osq -c %s %s %s' % (self.community,
self.addr, oid)
po = Popen(cmd, shell=True, stdout=PIPE, executable='/bin/bash')
output = po.communicate()[0]
result = dict()
for line in re.split(r'\r*\n', output):
if line.strip()=="":
continue
idx, value = re.split(r'\s+', line, 1)
idx = idx.replace(oid+".", '')
result[idx] = value
return result
def bulkwalk_index(self, oid='ifOutOctets'):
result = dict()
if not (self._index==dict()):
vals = self.bulkwalk(oid=oid)
for key, val in vals.items():
idx = self._index.get(key, None)
if not (idx is None):
result[idx] = val
else:
raise ValueError, "Could not find '%s' in the index (%s)" % self.index
else:
raise ValueError, "Call the index() method before calling bulkwalk_index()"
return result
def get_index(self, oid='ifOutOctets', index=''):
# This method is horribly inefficient... improvement left as exercise for the reader...
if index:
return self.bulkwalk_index().get(index, "<unknown>")
else:
raise ValueError, "Please include an index to get"
def index(self, oid='ifName'):
self._index = self.bulkwalk(oid=oid)
エンドノート:
SNMP v2c はクリアテキスト認証を使用します。セキュリティが心配な場合や誰かがあなたのトラフィックを傍受している場合は、コミュニティを変更して、Linux マシンへのクエリを送信元 IP アドレスで制限してください。完璧な世界は、SNMP.py
SNMPv3 (機密データを暗号化する) を使用するように上記を変更することです。ほとんどの人は、非公開コミュニティを使用して、送信元 IP によって snmp クエリを制限しています。
ifHCInOctets
ifHCOutOctets
インターフェイスを介して転送されたバイト数の瞬時値を提供します。データ転送速度を探している場合は、もちろん追加の計算が必要になります。