
%idle、memfree、available、pmeusedなど、特定の統計のみを収集する必要があります。また、出力をjson文字列に変換して使用する必要があります。
同じタスクを実行できるUNIXツールはありますか?
sarとSadfの組み合わせを試してみましたが、不要な複雑なjson形式がありました。
/usr/bin/sar -r 1 1 -o tmp1 &> 1;
/usr/bin/sadf tmp1 -j --iface=eth1 -- -u -r -n DEV
私は次のような結果を得ます。
{
"sysstat": {
"hosts": [{
"nodename": "ESDNAS1",
"sysname": "Linux",
"release": "4.4.143-94.47-default",
"machine": "x86_64",
"number-of-cpus": 8,
"file-date": "2019-08-02",
"file-utc-time": "04:53:09",
"statistics": [{
"timestamp": {
"date": "2019-08-02",
"time": "04:53:10",
"utc": 1,
"interval": 1
},
"cpu-load": [{
"cpu": "all",
"user": 0.25,
"nice": 0.00,
"system": 1.00,
"iowait": 0.00,
"steal": 0.00,
"idle": 98.75
}],
"memory": {
"memfree": 3707764,
"avail": 12451860,
"memused": 12013448,
"memused-percent": 45.01,
"buffers": 225176,
"cached": 4361204,
"commit": 28665304,
"commit-percent": 107.41,
"active": 13473076,
"inactive": 1535816,
"dirty": 616
},
"network": {
"net-dev": [{
"iface": "eth1",
"rxpck": 1.00,
"txpck": 1.00,
"rxkB": 0.11,
"txkB": 0.00,
"rxcmp": 0.00,
"txcmp": 0.00,
"rxmcst": 0.00,
"ifutil-percent": 0.00
}]
}
}],
"restarts": []
}]
}
}
私はこのようなもの(またはより簡単なもの)を探しています。
{
"sysstat": {
"hosts": [
{
"nodename": "HOSTNAME",
"statistics": [
{
"timestamp": {
"date": "2019-08-02",
"time": "04:53:10"
},
"cpu-load": [
{
"idle": 98.75
}
],
"memory": {
"memfree": 3707764,
"avail": 12451860,
"memused-percent": 45.01
},
"network": {
"net-dev": [
{
"iface": "eth1",
"rxpck": 1,
"txpck": 1,
"ifutil-percent": 0
}
]
}
}
],
"restarts": []
}
]
}
}
答え1
あなたはそれを使用することができますプスチルPythonでカスタムjsonを作成します。
psutil(Pythonシステムとプロセスユーティリティ)は、Pythonで実行されているプロセスとシステムの利用率(CPU、メモリ、ディスク、ネットワーク、センサー)に関する情報を取得するためのクロスプラットフォームライブラリです。主にシステムの監視、分析、プロセスリソースの制限、および実行中のプロセス管理に使用されます。これは、ps、top、lsof、netstat、ifconfig、who、df、kill、free、nice、ionice、iostat、iotop、uptime、pidof、tty、tasket、pmapなどのUNIXコマンドラインツールによって提供される多くの機能を実装します。
例:
import json
import psutil
def used_mem(json_key):
mem_total = psutil.virtual_memory().total
mem_percent = psutil.virtual_memory().percent
mem_used = psutil.virtual_memory().used
mem_free = psutil.virtual_memory().free
swap_percent = psutil.swap_memory().percent
swap_total = psutil.swap_memory().total
swap_used = psutil.swap_memory().used
json_key['free_mem'] = mem_free
json_key['total_mem'] = mem_total
json_key['mem_used'] = mem_used
json_key['percent_mem'] = mem_percent
json_key['swap_percent'] = swap_percent
json_key['swap_total'] = swap_total
json_key['swap_used'] = swap_used
json_key={}
used_mem(json_key)
print json.dumps(json_key)
出力:
{"swap_used": 14061568, "percent_mem": 48.3, "free_mem": 1792401408, "total_mem": 12447776768, "mem_used": 5128196096, "swap_total": 11999899648, "swap_percent": 0.1}
答え2
私の考えではジャック選択するツールです。
jq
JSONデータと同様に、あなたや友人がテキストを処理するsed
のと同じように、構造化されたデータを簡単に分割、フィルタリング、マッピング、変換するために使用できます。sed
awk
grep
Githubで素晴らしいチュートリアルをjq
見つけることができます。https://stedolan.github.io/jq/tutorial/ここに別の良いものがあります:https://programminghistorian.org/en/lessons/json-and-jq。
たとえば、「memfree」セクションにアクセスするには、コマンド出力を次jq
のようにパイプします。
... | jq .[].hosts[].statistics[].memory.memfree
これは作る:
3707764
または、JSONからメモリ全体の部分を取得するには、次の手順を実行します。
... | | jq .[].hosts[].statistics[].memory
これは作る:
{
"memfree": 3707764,
"avail": 12451860,
"memused": 12013448,
"memused-percent": 45.01,
"buffers": 225176,
"cached": 4361204,
"commit": 28665304,
"commit-percent": 107.41,
"active": 13473076,
"inactive": 1535816,
"dirty": 616
}
答え3
jq
元のコマンド(sar
またはsadf
)を調整して目的のJSONを生成できない場合は、以下のようにJSONパーサーを使用して調整してください。
jq '.sysstat.hosts[] |= { nodename, statistics : [ { timestamp : .statistics[].timestamp | { date, time },
"cpu-load": .statistics[]."cpu-load"[] | [{ idle }],
"memory": .statistics[].memory | { memfree, avail, "memused-percent" },
"network" : { "net-dev" : .statistics[].network."net-dev"[] | { iface, rxpck, txpck, "ifutil-percent"} } } ] , restarts}'
このフィルタが機能していることがわかりますjq-1.6のjq-遊び場