背景
產(chǎn)出系統(tǒng)拓?fù)鋱D,改圖中可以展示出系統(tǒng)全貌,如下圖所示

設(shè)計(jì)原理.png
思路
系統(tǒng)拓?fù)鋱D本質(zhì)上是一個(gè)“圖”,所以需要定義node節(jié)點(diǎn)以及edge邊緣,使其成為一個(gè)“圖”,同時(shí)node和edge的信息,可以去perf埋點(diǎn)的存儲(chǔ)中獲取。
給出一下定義node以及edge的數(shù)據(jù)結(jié)構(gòu)
{
"node":[
{
"id":"服務(wù)節(jié)點(diǎn)名",
"service":"可選-服務(wù)名",
"label":"",
"owner":"",
"type":"類型"
}
],
"edges":[
{
"id":0,
"source":"sourceId",
"target":"targetId"
}
]
}
- node中的id的作用就是去perf中獲取該節(jié)點(diǎn)的監(jiān)控信息;
- edge中的source和target也是去perf中獲取該節(jié)點(diǎn)的監(jiān)控信息;
但是需要注意的是,rpc接口中可能會(huì)存在一臺(tái)機(jī)器上存在多個(gè)service服務(wù)。而我們求的調(diào)用關(guān)系是api->service中。我們實(shí)際上關(guān)注的是調(diào)用某個(gè)service,而不是該機(jī)器上所有的服務(wù)。