1 回答

TA貢獻1876條經驗 獲得超7個贊
學習如何在 Go 中處理數據的一個很好的參考:http : //blog.golang.org/json-and-go
關于您的問題,在我看來,您的數據結構相對較好……我mem在以下操場示例中設置了提取每個節點部分的示例:
http://play.golang.org/p/0O5U-3N_tA
它的要點是任何被強烈指定的都可以編碼為structs。動態的(例如您的節點名稱)可以編碼為映射。兩者可以任意混合,這樣:
type Node struct {
Timestamp uint64 `json:timestamp`
Name string `json:name`
TransportAddress string `json:transport_address`
Host string `json:host`
Ip []string `json:ip`
Attributes map[string]string `json:attributes`
Os *OsInfo `json:os`
}
type Payload struct {
Name string `json:cluster_name`
Nodes map[string]*Node `json:nodes`
}
可以捕獲節點的一般結構(通過其struct定義)和它們被動態索引的事實(通過節點本身存儲在動態map.
一旦解組,處理你的數據以提取你的內存信息就很簡單了:它只是眾所周知的結構和映射:
var p Payload
if err := json.Unmarshal([]byte(payload), &p); err != nil {
log.Fatal(err)
}
for k, node := range p.Nodes {
fmt.Printf("%s: %s\n", k, node.Os.Mem)
}
按預期輸出:
Sd2AvEXsswjTn6ErRYjg: map[total_in_bytes:%!s(uint64=163987664) free_in_bytes:%!s(uint64=136357264) used_in_bytes:%!s(uint64=26629400) free_percent:%!s(uint64=84) used_percent:%!s(uint64=16)]
yzabB-OaTfOqvgAELIMq1Q: map[used_percent:%!s(uint64=99) total_in_bytes:%!s(uint64=623840000) free_in_bytes:%!s(uint64=4127648) used_in_bytes:%!s(uint64=666012352) free_percent:%!s(uint64=1)]
q5CdgUF2TRewujr-0RPMgQ: map[total_in_bytes:%!s(uint64=163898764) free_in_bytes:%!s(uint64=139705616) used_in_bytes:%!s(uint64=24194588) free_percent:%!s(uint64=85) used_percent:%!s(uint64=15)]
(您當然可以先提取/重新格式化您的數據,并在Payload完成后立即丟棄該對象)
- 1 回答
- 0 關注
- 179 瀏覽
添加回答
舉報