rrdデータをPythonにインポートするための良い方法はありますか? これまでに見つけた唯一のライブラリは、コマンド ラインの単なるラッパーか、rrd へのデータのインポートとグラフ化を提供するものです。
私は rrd のエクスポートとダンプのオプションを認識していますが、誰かがすでにここで大変な作業を行っているのではないかと思っています。
これは、サボテン rrd データを取得するために作成したスクリプトからの抜粋です。希望どおりになる可能性は低いですが、良いスタートを切れるかもしれません。私のスクリプトの目的は、Cacti をデータ ウェアハウスに変えることなので、多くの平均、最大、または最小データを引き出す傾向があります。また、「バイト/秒」を「mb/時間」などのより使いやすいものに変換したい場合に備えて、上限または下限の範囲のスパイクを投げるためのフラグもいくつかあります...
正確な 1 対 1 のデータ コピーが必要な場合は、これを少し調整する必要があるかもしれません。
value_dict = {}
for file in files:
if file[0] == '':
continue
file = file[0]
value_dict[file] = {}
starttime = 0
endtime = 0
cmd = '%s fetch %s %s -s %s -e %s 2>&1' % (options.rrdtool, file, options.cf, options.start, options.end)
if options.verbose: print cmd
output = os.popen(cmd).readlines()
dsources = output[0].split()
if dsources[0].startswith('ERROR'):
if options.verbose:
print output[0]
continue
if not options.source:
source = 0
else:
try:
source = dsources.index(options.source)
except:
print "Invalid data source, options are: %s" % (dsources)
sys.exit(0)
data = output[3:]
for val in data:
val = val.split()
time = int(val[0][:-1])
val = float(val[source+1])
# make sure it's not invalid numerical data, and also an actual number
ok = 1
if options.lowerrange:
if val < options.lowerrange: ok = 0
if options.upperrange:
if val > options.upperrange: ok = 0
if ((options.toss and val != options.toss and val == val) or val == val) and ok:
if starttime == 0:
# this should be accurate for up to six months in the past
if options.start < -87000:
starttime = time - 1800
else:
starttime = time - 300
else:
starttime = endtime
endtime = time
filehash[file] = 1
val = val * options.multiply
values.append(val)
value_dict[file][time] = val
seconds = seconds + (endtime - starttime)