DPDK編程指南(翻譯)( 二十八)

28. Metrics 庫(kù)

Metrics 庫(kù)實(shí)現(xiàn)了一個(gè)機(jī)制,通過(guò)這個(gè)機(jī)制,producers 可以發(fā)布numeric信息,供 consumers 后續(xù)查詢。
實(shí)際上,生產(chǎn)者通常是其他庫(kù)或者主進(jìn)程,而消費(fèi)者通常是應(yīng)用程序。

Metrics 本身是一個(gè)靜態(tài)值,并不是有PMD產(chǎn)生的。
Metric 信息是由推送模型填充的,其中生產(chǎn)者通過(guò)調(diào)用相關(guān)的更新函數(shù)來(lái)跟新metric庫(kù)中包含的值。
消費(fèi)者通過(guò)查詢共享內(nèi)存中的metric數(shù)據(jù)來(lái)獲取metric信息。

對(duì)于每個(gè)mettic,為每個(gè)端口ID保留一個(gè)單獨(dú)的值,并且在發(fā)布metric時(shí),生產(chǎn)者需要指定哪個(gè)端口正在更新。
此外,還有一個(gè)特殊的ID RTE_METRICS_GLOBAL, 用于全局統(tǒng)計(jì),不與任何單個(gè)設(shè)備關(guān)聯(lián)。
由于metric庫(kù)是自包含的,因此,對(duì)端口號(hào)的唯一限制是他們小于 RTE_MAX_ETHPORTS,不需要實(shí)際端口存在。

28.1. 初始化庫(kù)

在使用庫(kù)之前,必須通過(guò)調(diào)用在共享內(nèi)存中設(shè)置mettic存儲(chǔ)的 rte_metrics_init() 來(lái)初始化它。
這也就是生產(chǎn)者將metric信息發(fā)布到哪里以及消費(fèi)者從哪里查新metric信息。

rte_metrics_init(rte_socket_id());

這個(gè)初始化函數(shù)必須在主函數(shù)中調(diào)用,否則生產(chǎn)者和消費(fèi)者可能在主程序或次進(jìn)程中多次調(diào)用。??

28.2. 注冊(cè)metrics

Metrics 必須先注冊(cè),這是生產(chǎn)者聲明他們將要發(fā)布的metric的方式。注冊(cè)可以單獨(dú)完成,也可以將一組metric標(biāo)注為一個(gè)組。單獨(dú)注冊(cè)使用接口 rte_metrics_reg_name() 實(shí)現(xiàn):

id_1 = rte_metrics_reg_name("mean_bits_in");
id_2 = rte_metrics_reg_name("mean_bits_out");
id_3 = rte_metrics_reg_name("peak_bits_in");
id_4 = rte_metrics_reg_name("peak_bits_out");

一組metric注冊(cè)使用 rte_metrics_reg_names() 完成:

const char * const names[] = {
    "mean_bits_in", "mean_bits_out",
    "peak_bits_in", "peak_bits_out",
};
id_set = rte_metrics_reg_names(&names[0], 4);

如果返回負(fù)數(shù),表示注冊(cè)失敗。否則,返回值表示更新metic時(shí)使用的 key 值??梢允褂?rte_metrics_get_names() 獲得將這些key值與metric名稱映射起來(lái)的映射表。

28.3. 更新 metric 值

一旦注冊(cè),生產(chǎn)者可以使用 rte_metrics_update_value() 函數(shù)更新給定端口的metric。這個(gè)函數(shù)使用metric注冊(cè)時(shí)返回的key值,也可以使用 rte_metrics_get_names() 查找。

rte_metrics_update_value(port_id, id_1, values[0]);
rte_metrics_update_value(port_id, id_2, values[1]);
rte_metrics_update_value(port_id, id_3, values[2]);
rte_metrics_update_value(port_id, id_4, values[3]);

如果metric被注冊(cè)為一個(gè)集合,則可以使用 rte_metrics_update_value() 單獨(dú)更新他們,或者使用 rte_metrics_update_values() 一起更新:

rte_metrics_update_value(port_id, id_set, values[0]);
rte_metrics_update_value(port_id, id_set + 1, values[1]);
rte_metrics_update_value(port_id, id_set + 2, values[2]);
rte_metrics_update_value(port_id, id_set + 3, values[3]);

rte_metrics_update_values(port_id, id_set, values, 4);

注意,rte_metrics_update_values() 不能用來(lái)更新 multiple sets 的metric,因?yàn)椴荒鼙WC兩個(gè)集合一個(gè)接一個(gè)地注冊(cè)了連續(xù)的ID值。

28.4. 查詢 metrics

消費(fèi)者可以通過(guò)使用返回 struct rte_metric_value 數(shù)組的接口 rte_metrics_get_values() 來(lái)查詢metric庫(kù)。 該數(shù)組中的每個(gè)條目都包含一個(gè)metric值及其關(guān)聯(lián)的key。key值和名稱的映射可以使用 rte_metrics_get_names() 函數(shù)來(lái)獲得,該函數(shù)返回由key索引的 struct rte_metric_name 數(shù)組。以下將打印給定端口的所有metric:

void print_metrics() {
    struct rte_metric_name *names;
    int len;

    len = rte_metrics_get_names(NULL, 0);
    if (len < 0) {
        printf("Cannot get metrics count\n");
        return;
    }
    if (len == 0) {
        printf("No metrics to display (none have been registered)\n");
        return;
    }
    metrics = malloc(sizeof(struct rte_metric_value) * len);
    names =  malloc(sizeof(struct rte_metric_name) * len);
    if (metrics == NULL || names == NULL) {
        printf("Cannot allocate memory\n");
        free(metrics);
        free(names);
        return;
    }
    ret = rte_metrics_get_values(port_id, metrics, len);
    if (ret < 0 || ret > len) {
        printf("Cannot get metrics values\n");
        free(metrics);
        free(names);
        return;
    }
    printf("Metrics for port %i:\n", port_id);
    for (i = 0; i < len; i++)
        printf("  %s: %"PRIu64"\n",
            names[metrics[i].key].name, metrics[i].value);
    free(metrics);
    free(names);
}

28.5. Bit-rate 統(tǒng)計(jì)庫(kù)

Bit-rate 庫(kù)計(jì)算每個(gè)活動(dòng)端口(即網(wǎng)絡(luò)設(shè)備)的指數(shù)加權(quán)平均值和峰值比特率。
這些統(tǒng)計(jì)信息通過(guò)metric庫(kù)使用以下名稱進(jìn)行發(fā)布:

  • mean_bits_in: 平均入站比特率
  • mean_bits_out: 平均出站比特率
  • ewma_bits_in: 平均入站比特率 (EWMA 平滑)
  • ewma_bits_out: 平均出站比特率 (EWMA 平滑)
  • peak_bits_in: 峰值入站比特率
  • peak_bits_out: 峰值出站比特率

一旦初始化,并以適當(dāng)?shù)念l率計(jì)時(shí),可以通過(guò)查詢metric庫(kù)來(lái)獲取metric值。

28.5.1. 初始化

在使用庫(kù)之前,必須通過(guò)接口 rte_stats_bitrate_create() 來(lái)初始化,這個(gè)函數(shù)返回一個(gè)bit-rate計(jì)算對(duì)象。由于bit-rate庫(kù)使用metric來(lái)報(bào)告計(jì)算的統(tǒng)計(jì)量,因此bit-rate庫(kù)需要將計(jì)算的統(tǒng)計(jì)量與metric庫(kù)一起注冊(cè)。這通過(guò)輔助函數(shù) rte_stats_bitrate_reg() 完成。

struct rte_stats_bitrates *bitrate_data;

bitrate_data = rte_stats_bitrate_create();
if (bitrate_data == NULL)
    rte_exit(EXIT_FAILURE, "Could not allocate bit-rate data.\n");
rte_stats_bitrate_reg(bitrate_data);

28.5.2. 控制采樣速率

由于庫(kù)通過(guò)定期采樣來(lái)工作,而不是使用內(nèi)部線程,應(yīng)用程序必須定期調(diào)用 rte_stats_bitrate_calc() 。 這個(gè)函數(shù)被調(diào)用的頻率應(yīng)該是計(jì)算統(tǒng)計(jì)所需要的預(yù)期采樣頻率。 例如,需要按秒統(tǒng)計(jì),那么應(yīng)該每秒鐘調(diào)用一次這個(gè)函數(shù)。

tics_datum = rte_rdtsc();
tics_per_1sec = rte_get_timer_hz();

while( 1 ) {
    /* ... */
    tics_current = rte_rdtsc();
    if (tics_current - tics_datum >= tics_per_1sec) {
        /* Periodic bitrate calculation */
        for (idx_port = 0; idx_port < cnt_ports; idx_port++)
                rte_stats_bitrate_calc(bitrate_data, idx_port);
            tics_datum = tics_current;
        }
    /* ... */
}

28.6. 延遲統(tǒng)計(jì)庫(kù)

延遲統(tǒng)計(jì)庫(kù)計(jì)算DPDK應(yīng)用程序的數(shù)據(jù)包處理延遲,報(bào)告數(shù)據(jù)包處理所需的最小,平均和最大納秒,以及處理延遲中的抖動(dòng)。使用以下名稱通過(guò)metric庫(kù)報(bào)告這些統(tǒng)計(jì)信息:

  • min_latency_ns: 最小處理延遲(納秒)
  • avg_latency_ns: 平均處理延遲(納秒)
  • mac_latency_ns: 最大處理延遲(納秒)
  • jitter_ns: 處理等待時(shí)間的變化(納秒)

一旦初始化并以適當(dāng)?shù)念l率采樣,可以通過(guò)查詢metric庫(kù)來(lái)獲得這些統(tǒng)計(jì)數(shù)據(jù)。

28.6.1. 初始化

使用庫(kù)之前,需要調(diào)用函數(shù) rte_latencystats_init() 進(jìn)行初始化。

lcoreid_t latencystats_lcore_id = -1;

int ret = rte_latencystats_init(1, NULL);
if (ret)
    rte_exit(EXIT_FAILURE, "Could not allocate latency data.\n");

28.6.2. 觸發(fā)統(tǒng)計(jì)值更新

需要定期調(diào)用 rte_latencystats_update() 函數(shù),以便更新延遲統(tǒng)計(jì)值信息。

if (latencystats_lcore_id == rte_lcore_id())
    rte_latencystats_update();

28.6.3. 關(guān)閉庫(kù)

完成之后,需要調(diào)用 rte_latencystats_uninit() 來(lái)關(guān)閉延遲統(tǒng)計(jì)庫(kù)。

rte_latencystats_uninit();
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,673評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 178,610評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 63,939評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,668評(píng)論 6 412
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 56,004評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評(píng)論 3 449
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 43,173評(píng)論 0 290
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,705評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,426評(píng)論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,656評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,833評(píng)論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 35,247評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 36,580評(píng)論 1 295
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,371評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,621評(píng)論 2 380

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,829評(píng)論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,923評(píng)論 6 342
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,761評(píng)論 25 708
  • ◆◆◆特別聲明◆◆◆ 本篇文章系本人學(xué)習(xí)《廖雪峰Git教程》筆記,主要用作自己復(fù)習(xí)使用。首先向廖雪峰老師表示感謝,...
    CalvinNing閱讀 587評(píng)論 0 1
  • 五一小長(zhǎng)假已過(guò)完,聽(tīng)說(shuō)你的心還沒(méi)收回來(lái).....五一都去哪里玩耍了呢?出來(lái)扒一扒吧~ 我是去了這里! 登封白沙湖文...
    跟著啦啦去旅行閱讀 1,457評(píng)論 0 0