Orleans解決并發之痛(六):Dashboard

Orleans Dashboard 是來自 OrleansContrib 提供的一個 Orleans 報表工具。通過 Orleans Dashboard 我們能很方便的監控 Silos 狀態、Grains 分布情況、異常率、吞吐量、平均響應時間等,這樣我們就能了解集群的運行平穩性,也能排除錯誤和性能瓶頸。

初始項目的代碼根據之前的案例 Demo-OrleansCluster 稍微做了調整,Orleans Dashboard 的使用方法還是比較簡單的。

  1. NuGet 安裝 OrleansDashboard:
Install-Package OrleansDashboard
  1. 修改配置文件 OrleansConfiguration.xml,Globals 節點下添加 BootstrapProviders 節點:
<Globals>
  ......
  <BootstrapProviders>
    <Provider Type="OrleansDashboard.Dashboard" Name="Dashboard" />
  </BootstrapProviders>
</Globals>

完成以上工作就可以啟動 Silo 了。

Silo 啟動成功后,Orleans Dashboard 默認訪問地址是 localhost:8080。如果你想修改端口或者添加安全驗證,可以根據配置參數來調整 Configuring the Dashboard

注意:啟動過程中可能會出現下面這個錯誤:

System.AggregateException: 發生一個或多個錯誤。 ---> System.DllNotFoundException: 無法加載 DLL“libuv”: 找不到指定的模塊。 (異常來自 HRESULT:0x8007007E)。

在 OrleansDashboard 的 issues 下已有人提到,可以關注一下 :https://github.com/OrleansContrib/OrleansDashboard/issues/62

我暫時采用的方案是: 將 \packages\Libuv.1.10.0\runtimes\win-x86\native\libuv.dll) 復制到 bin\Debug\ 下,重新啟動就可以跑起來了。

Overview

在 Orleans Dashboard 概述中可以了解到當前集群激活的 Grains 數量、Silos 數量、錯誤率、吞吐量、平均響應時間及整體的性能情況。

Overview

Grains

Grains 模塊統計出當前所有激活的 Grains 以及 Grains 的數量變量趨勢,我們可以通過點擊每個 Grain 詳情查看更詳細信息,詳情下包括 Grain 下的所有方法的調用情況及當前 Grain 歸屬的 Silo:

Grain

Silos

Silos 模塊概述和 Grains 類似,報表會呈現當前集群 Silo 的健康狀態,通過 Silo 的詳情我們可以了解到:

  1. 當前服務器的 CPU、內存、Grain 是使用情況;
  2. Silo 性能分析;
  3. 消息的發送和接收狀況和 Silo 的一些屬性;
  4. 分布著哪些 Grains;
Silo.png

本文是使用一個 Silo 實例來實現,如果是集群,可以參考 Demo-OrleansCluster 。Silo 的配置文件內加上 OrleansDashboard 的配置即可。如果是同一臺機器,注意端口號分別指定一下。

在 Client 端添加測試代碼,直接粗暴點來個死循環:

var random = new Random();
while (true)
{
    var grainId = random.Next();
    var grain = GrainClient.GrainFactory.GetGrain<IPersonGrain>("beck" + grainId);
    grain.SayHelloAsync().Wait();
}

測試結果:

PersonGrain

Silo

參考鏈接:

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

推薦閱讀更多精彩內容