うまくいけば、これは少し助けになります。
ですから、私が書いたプログラムをお見せしましょう。cronの動作に問題があったからです。残念ながらシェルスクリプトのことは知らないので、これはpythonで行われますが、私にとってはうまくいきました。かなりシンプルですが、すばらしいです。申し訳ありませんが、コードにはコメントしませんでしたが、実際にコードを確認したくありませんでした。一部のパーツが最適でない可能性があることはわかっていますが、問題なく機能します。
def main():
while True:
import time
import os
from subprocess import call
schedule=tim3()
print(schedule)
interface=" "
while interface==" ":
interface=input("""
Enter your interface:
(Be careful there is no error checking for this part)
Examples are eth0, wlan0...
""")
if interface == "":
break
while True:
x= clogger(schedule[2],schedule[3],schedule[4],\
schedule[5],interface)
if x== "done":
break
while True:
x= exit_q()
if x== "y":
user_exit=input('''
How would you like your output?
Type (From vnstat --longhelp):
q, --query query database
h, --hours show hours
d, --days show days
m, --months show months
w, --weeks show weeks
t, --top10 show top10
s, --short use short output
''')
call(["vnstat", "-"+str(user_exit), "-i", str(interface),])
break
break
def tim3():
import time
#current_time=["16", "20"]
tim3= time.strftime("%H %M")
current_time=tim3.split()
print("""
"""+ str(tim3)+"""
Current time
""")
hour=current_time[0]
minute=current_time[1]
ui = inputs()
newlist=[hour, minute]
schedule=newlist+ui
print(schedule)
return schedule
def inputs():
print("""
------------------------------------------
""")
while True:
start_hour=(input("Enter the starting hour (24hr): "))
start_min=(input("Enter the starting minute: "))
x = checker(start_hour, start_min)
endh=(input("How many hours would you like to run? "))
endm=(input("How many minutes would you like to run? "))
y = checker(endh,endm)
if str(x)=="Great":
if str(y) == "Great":
return [start_hour, start_min, endh, endm]
def checker(h,m):
error=0
message=("Incorrect Format")
while error==0:
if h =="":
print(message)
break
if len(str(h))> 2:
print(message)
break
if m =="":
print(message)
break
if len(str(m))>2:
print(message)
break
for x in str(h):
if x.isdigit() == False:
error+=1
print(message)
break
if error>0:
print(message)
break
for y in str(m):
if y.isdigit() == False:
error+=1
print(message)
break
if error>0:
print(message)
break
else:
return("Great")
def clogger(s1,s2,t1,t2,I):
import time
import os
from subprocess import call
total_time=int(t1)*60*60+int(t2)*60
while True:
h1=int(time.strftime('%H'))
m2=int(time.strftime('%M'))
if len(str(s1))<2:
s1="0"+str(s1)
if len(str(s2))<2:
s2="0"+str(s2)
if len(str(h1))<2:
h1="0"+str(h1)
if str(h1)==str(s1) and str(m2)==str(s2):
while True:
if total_time>0:
call (["vnstat", "-i",str(I)])
time.sleep(15)
total_time=total_time-15
print(total_time," seconds")
elif total_time<=0:
return "done"
time.sleep(15)
def exit_q():
while True:
question=input("Would you like to show a report? (y/n) ")
if question == "y" or question == "n":
return question
main()
クイックガイド
監視しているデバイスを入力します(私はエラーチェックを行わなかったため、monkeybuttのようなものを入力すると、vnstat -i monkeybutt
15秒ごとにCtrl+ Cアウトして実行されます)。
プログラムは15秒ごとに実行され、時間が一致するかどうかを確認します。メッセージは表示されません。これはバックグラウンドで実行されることを意図しています。起動すると、選択したデバイス上で、ネットワークの15秒ごとにショットを撮ります。vnstatコマンドと、モニターの残り時間(秒)を示すカウンターを使用します。
スキャンが完了すると、終了するかどうかを尋ねられ、レポートを表示するかどうかのオプションが表示されます。それ以外の場合は、単に終了できます。すべてのものはとにかくvnstatsデータベースに保存されます。
投稿の古い部分(一部の人には役立つかもしれません)
gnome-scheduleを取得してから、たとえばvnstat -hなどのコマンドを入力して、監視しようとしているときに繰り返し発生するように設定できます。多分単純すぎるかもしれませんが、うまくいけば、他の誰かがさらに拡大することができます。
追加(編集):私はvnstatをあまり使用していないため、誰かがその部分を拡張できることを望んでいましたが、gnome-scheduleを使用すると、特定の時間帯に実行するコマンドをスケジュールできます。したがって、vntstat -tr -l(トラフィックスイッチ、ライブトラフィックを監視)を使用すると、実行中にトラフィックが表示されます(gnome-scheduleでスケジュールできますが、手動でCtrl+ C]アウトする必要がある場合があります)。
それ以外の場合は、これをファイルにパイプするか、vnstatのグラフィック出力プログラムを使用している場合はそれを使用できると確信しています。グラフ出力プログラムはvnstati -i 'filename'
pngファイルに出力します。さらにコマンドが必要な場合は、vnstat --longhel
pにさらにコマンドがあります。
(物をgnome-scheduleに入れる方法のサンプル画面。)
vnstatを使用して帯域幅の「スナップショット」を取得する方法を知っていますか、またはそれらのコマンドについてさらにヘルプが必要ですか?このプログラムをもっと使ってみることができます。