《通過C#學Proto.Actor模型》之Prpos

来源:https://www.cnblogs.com/axzxs2001/archive/2018/08/27/9540265.html
-Advertisement-
Play Games

在第一篇Proto.Actor博文中,HelloWorld的第一行真正代碼是: var props = Actor.FromProducer(() => new HelloActor()); 這個返回的變數props就是一個Props的對象,它是負責創Actor實例,以及配置Actor實例,並... ...


在第一篇Proto.Actor博文中,HelloWorld的第一行真正代碼是:

   var props = Actor.FromProducer(() => new HelloActor());

這個返回的變數props就是一個Props的對象,它是負責創Actor實例,以及配置Actor實例,並且產Actor上下文Context(類似asp.net中的Context)。

Props對象產生通常是用Actor.FromProducer或Actor.FromFunc產生,不過也可能實例化,實體例時可以給Actor做一系列配置,如下代碼:

 1 using Proto;
 2 using Proto.Mailbox;
 3 using System;
 4 using System.Threading.Tasks;
 5 
 6 namespace P002_CustomProps
 7 {
 8     class Program
 9     {
10         static void Main(string[] args)
11         {
12             var props = new Props()
13                 //用道具代理返回一個IActor實例
14                 .WithProducer(() => new MyActor())
15                 //預設調度器用線程池,郵箱中最多300個消息吞吐量
16                 .WithDispatcher(new ThreadPoolDispatcher { Throughput = 300 })
17                 //預設郵箱使用無界隊列
18                 .WithMailbox(() => UnboundedMailbox.Create())
19                 //預設策略在10秒的視窗內最多重新啟動子Actor 10次
20                 .WithChildSupervisorStrategy(new OneForOneStrategy((who, reason) =>
21                 SupervisorDirective.Restart, 10, TimeSpan.FromSeconds(10)))
22                 //可以將中間件鏈接起來以攔截傳入和傳出消息 
23                 //接收中間件在Actor接收消息之前被調用
24                 //發送者中間件在消息發送到目標PID之前被調用
25                 .WithReceiveMiddleware(
26                 next => async c =>
27                 {
28                     Console.WriteLine($"Receive中間件 1 開始,{c.Message.GetType()}:{c.Message}");
29                     await next(c);
30                     Console.WriteLine($"Receive中間件 1 結束,{c.Message.GetType()}:{c.Message}");
31                 },
32                 next => async c =>
33                 {
34                     Console.WriteLine($"Receive中間件 2 開始,{c.Message.GetType()}:{c.Message}");
35                     await next(c);
36                     Console.WriteLine($"Receive中間件 2 結束,{c.Message.GetType()}:{c.Message}");
37                 })
38                 .WithSenderMiddleware(
39                 next => async (c, target, envelope) =>
40                 {
41                     Console.WriteLine($"Sender中間件 1 開始, {c.Message.GetType()}:{c.Message}");
42                     await next(c, target, envelope);
43                     Console.WriteLine($"Sender中間件 1 結束,{c.Message.GetType()}:{c.Message}");
44                 },
45                 next => async (c, target, envelope) =>
46                 {
47                     Console.WriteLine($"Sender中間件 2 開始,{c.Message.GetType()}:{c.Message}");
48                     await next(c, target, envelope);
49                     Console.WriteLine($"Sender中間件 2 結束,{c.Message.GetType()}:{c.Message}");
50                 })
51                 // 預設的 spawner 構造  Actor, Context 和 Process
52                 .WithSpawner(Props.DefaultSpawner);
53 
54             //從props衍生pid,pid代理一個actor的地址
55             var pid = Actor.Spawn(props);       
56             //把Hello對象交給HelloActor處理
57             pid.Tell(new MyEntity
58             {
59                 Message = "我是MyEntity的Message,請求"
60             });
61             Console.ReadLine();    
62         }
63     }
64 
65     public class MyActor : IActor
66     {
67         public Task ReceiveAsync(IContext context)
68         {
69             if (context.Message is MyEntity myEntity)
70             {
71                 Console.WriteLine(myEntity.Message);
72                 context.Tell(context.Sender, new MyEntity() { Message = "我是MyEntity的Message,應答" });
73             }
74             return Actor.Done;
75         }
76     }
77     public class MyEntity
78     {
79         public string Message { get; set; }
80     }
81 }

你會發現,Demo中,總有一個實例類+一個Actor類,這是構成Actor模型的必備,Actor類就是主體,實體類就是Actor類運算的載體,所以它們總是如影隨形。

 第15 行到第21 行代碼含意以後會解釋。 

這裡說Recevie和Sender的中間件,這裡很像一個AOP,可以在調用某個行為前後作處理統一的處理,比如日誌,許可權等統一的規則,也和asp.net core里的中件間如出一轍【如里你是一個asp.net core碼友,熟悉的Context,熟悉的next(),還有熟悉的Middleware】。

現在可以自己運行一下分析一下結果吧:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一.構建工程 1.引入依賴 2.創建主類 3.配置application.properties 這裡存在 api-a 和 api-b 兩個微服務應用, 當請求http://localhost:port/api-a/helloWorld, 會被路由轉發至 api-a 服務的 /helloWorld 接 ...
  • 網路傳輸模型 基本模型 層次劃分 需要說明的是在網路傳輸層TCP可靠而UDP不可靠 傳輸層說明 說明一: 作為Python開發,咱們都是在應用層的HTTP協議之上進行開發的。 說明二: 網路編程,主要是瞭解我們Python能編寫的最低的層次, 即傳輸層的基本情況。 說明三: HTTP協議是基於TCP ...
  • 馬上又是一個金九銀十的招聘旺季,小編在這裡給大家整理了一套各大互聯網公司面試都喜歡問的一些問題或者一些出場率很高的面試題,給在校招或者社招路上的你一臂之力。 首先我們需要明白一個事實,招聘的一個很關鍵的因素是在給自己找未來的同事,同級別下要找比自己優秀的人,面試是一個雙向選擇的過程,也是一個將心比心 ...
  • 一、生成器的定義 在函數中使用yield關鍵字,由函數返回的結果就是生成器。 1 def gen(): 2 print('gen') #函數內部的代碼不執行 3 yield 0 4 yield 1 5 yield 2 6 7 g = gen() 8 print(g) 9 print(next(g)) ...
  • 集群健康檢查 取得健康狀態 GET /_cat/health?v 返回: 健康狀態分類 green:索引的primary shard和replica shard都是active狀態的 yellow:索引的primary shard都是active狀態的,但是部分replica shard不是acti ...
  • 參考來源:https://www.cnblogs.com/liwenzhou/p/8747872.html ...
  • 小編也不知道大家能不能用的到,我只是把我學到的知識分享出來,有需要的可以看一下。python本身就是一個不斷更新改進的語言,不存在抄襲,有需要就可以拿過來用,在用的過程中,你發現可以用另外一種方法把它實現,就可以把代碼做進一步的優化,然後分享出來,這樣python會變的越來越實用。今天心情不好,分享 ...
  • 前言 編程其實就是寫代碼,而寫代碼目的就是實現業務,所以,語法和框架也是為了實現業務而存在的。因此,不管多麼高大上的目標,實質上都是業務。 所以,我認為不要把寫代碼上升到科學的高度。上升到藝術就可以了,因為藝術本身也沒有高度。。。。 軟體設計存在過度設計,語法和框架的理解,也存在過度理解。比如,反編 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...