サーバーのリソースを見るgostatを作りました

最近go言語を勉強し始めています。

ということで、勉強の一環として、サーバーのリソースを表示してくれる gostat というものを作成してました。

https://bitbucket.org/r_rudi/gostat

使い方

% mkdir gostat
% cd gostat
% export GOPATH=`pwd`
% go get bitbucket.org/r_rudi/gostat

で、gostat/bin/gostatという実行ファイルが出来上がります。

なにができるの?

iostatや dstat と同じように、 サーバーのリソース状態を表示してくれます。

現時点では

  • load avg

  • mem

  • cpu

  • aio

が取得できます。module構造にしているので、どんどん増やせますが、今はこ れぐらいです。

実行するとこんな感じです。

% ./bin/gostat
time:2013-05-30 21:35:33.781308848 +0900 JST    tag:load load1:0.00      load5:0.00      load15:0.00
time:2013-05-30 21:35:33.78152943 +0900 JST     tag:memory usage MemFree:168052  Buffers:133404  Cached:537612
time:2013-05-30 21:35:33.981724611 +0900 JST    tag:cpu usr:0.00 sys:0.00        idl:0.00        wai:83.33       hiq:0.00

-i をつけると、指定した秒数ごとに表示を繰りかえします。

出力形式

さっきの表示を見て、iostatと違うな…、と思った方も多いと思います。標準 では LTSV 形式で標準出力に出します。

この他、

  • whitespace

  • csv

という表示形式に加えて、

  • http

  • mqtt

に対応しました。

これらは -o オプションで指定できます。

% ./bin/gostat -o csv
aio,load1,load5,load15,MemFree,Buffers,Cached,usr,sys,idl,wai,hiq,siq,stl
0,0.00,0.00,0.00,168176,133408,537612,0.00,0.00,0.00,125.00,0.00,0.00,0.00

http

httpを指定した場合、任意のURLにPOSTします。

% ./bin/gostat -o http http://fluentd.example.com:9880

ペイロードは、jsonというkeyでJSON形式を送ります。これはつまり、 fluentdのin_http が受け取 る形式と同じです。

mqtt

MQTT (MQ Telemetry Transport) とはM2M、 Machine-to-Machineでの通信のために作られたプロトコルです。オーバーヘッ ドがかなり小さい、publish/subscribe型のプロトコルです。

ブローカーと呼ばれるサーバーに対してpublish/subscribeを行います。 gostatは指定したブローカーに対してpublishします。

% ./bin/gostat -o mqtt -i 5 test.mosquitto.org:1883 gostat/rudi/

こうしておけば、

% mosquitto_sub -h test.mosquitto.org -t "gostat/rudi/#"
{"aio":"0","tag":"aio","time":"2013-05-30 12:51:59.28449373 +0000 UTC"}
{"load1":"0.00","load15":"0.00","load5":"0.00","tag":"load","time":"2013-05-30  12:51:59.284621107 +0000 UTC"}
{"Buffers":"133424","Cached":"537616","MemFree":"167648","tag":"memory usage","time":"2013-05-30 12:51:59.28478457 +0000 UTC"}

というように、JSON形式で受け取れます。

MQTTは AWSのmidiumサイズのインスタンスで100Kの同時接続をさばいたという 話 がある ようにかなり大規模に使えるプロコトルです。AMQPのようなQueueとしては(名 前に反して)使えませんが、大規模に通知する場合には使えるかと思います。

MQTTの話はまたの機会に。

まとめ

go言語の勉強として、リソースを取得してくれるgostatを作ってみました。単 に表示するだけでは面白くないので、LTSVにしてみたり、httpやMQTTを送って みたりといろいろ試してみました。

ちなみに中身はdstatをかなり真似しています。そしてdstatはLinuxべったりな んですよね…

あと、特色としてはMQTTに対応したところですね。MQTTは組み込みなど省リソー ス向けですし、go言語はクロスコンパイルが容易ですから相性はいいかもな、 と思っているところです。

まだまだ実装した部分は少ないので、需要があればもっといろいろな情報を取 れるように実装していきます。

Comments