Actor-ES框架:Actor编写-ESGrain与ESRepGrain

ESGrain
生命周期

Ray中ESGrain继承自Grain扩展了Grain的生命周期。Grain的生命周期参加文档附录:1-Grain生命周期-译注.md

ESGrain重写了Grain的OnActivateAsync方法。ESGrain的初始化过程如下:

  • 初始化ESGrain中的State

    • 调用ReadSnapshotAsync()读快照。

    • 如果没有获得快照,调用InitState()根据InitState()中代码初始化ESGrain,InitState()是虚方法,可以被具体的ESGrain重写,以自定义初始化。

  • 读取事件库,重放事件,获得最新的State。


小技巧:在实际开发中,可以重写InitState(),在其中根据关系型数据库中的数据自定义state的初始化。


使用

State

ESGrain的数据存储在State中,当ESGrain被激活后State数据存储在内存中,持久化会存储为快照。定义ESGrain时,需要定义State,实现IState接口,序列化默认使用protocol buffer,State类要添加protocol buffer特性。IState接口定义的是State的基础部分,即示例中的base部分,base之外的是当前actor需要的要存储的数据。

示例代码:

[ProtoContract(ImplicitFields = ImplicitFields.AllFields)] public class AccountState : IState<string> {     #region base     public string StateId { get; set; }     public uint Version { get; set; }     public uint DoingVersion { get; set; }     public DateTime VersionTime { get; set; }     #endregion     public decimal Balance { get; set; } }

Event

ESGrain之间通过Event传递数据,Event编写请参考Event编写.md

EventHandles

使用ESGrain引发事件,一般出于两种考虑:1.传递数据到Handler;2.修改State中的数据。修改ESGrain中的数据通过EventHandle中的代码实现。

使用:

    • 实现IEventHandle

    • 在Apply中实现定义要处理的事件。

      示例代码:

    public class AccountEventHandle : IEventHandle

    {

      public void Apply(object state, IEvent evt)

      {

          if (state is AccountState actorState)

          {

              switch (evt)

              {

                  case AmountAddEvent value: AmountAddEventHandle(actorState, value); break;

                  case AmountTransferEvent value: AmountTransferEventHandle(actorState, value); break;

                  default: break;

              }

          }

      }

      private void AmountTransferEventHandle(AccountState state, AmountTransferEvent evt)

      {

          state.Balance = evt.Balance;

      }

      private void AmountAddEventHandle(AccountState state, AmountAddEvent evt)

      {

          state.Balance = evt.Balance;

      }

    }



      • State中的数据存储在内存中,大量的数据存在State中,在某种角度可以将State看做内存数据库。

      • Ray中,修改State的数据要通过EventHandle实现(只有一种方式)。

      ESGrain种类

      • Ray默认提供了MongoESGrain和SqlGrain两类。

        ESGrain<K, S, W>说明:

      • K:StateId的类型。

      • S:ESGrain的State。

      • W:MessageInfo。

      完整ESGrain示例

      编写ESGrain时

      • 明确RabbitPub。

      • 明确MongoStorage。

      • 继承MongoESGrain或SqlGrain。

      • 实现ESGrain接口。

      • 如果需要重写OnActivateAsync。

      • 编写感兴趣的Actor方法

      • 如果需要发送事件:1.定义事件;2.编写EventHandler。

      [RabbitMQ.RabbitPub("Account", "account")]

      [MongoStorage("Test", "Account")]

      public sealed class Account : MongoESGrain<String, AccountState, IGrains.MessageInfo>, IAccount

      {

          protected override string GrainId => this.GetPrimaryKeyString();


          static IEventHandle _eventHandle = new AccountEventHandle();

          protected override IEventHandle EventHandle => _eventHandle;


          public override Task OnActivateAsync()

          {

              return base.OnActivateAsync();

          }

          public Task Transfer(string toAccountId, decimal amount)

          {

              var evt = new AmountTransferEvent(toAccountId, amount, this.State.Balance - amount);

              return RaiseEvent(evt).AsTask();

          }

          public Task AddAmount(decimal amount, string uniqueId = null)

          {

              var evt = new AmountAddEvent(amount, this.State.Balance + amount);

              return RaiseEvent(evt, uniqueId: uniqueId).AsTask();

          }

          [AlwaysInterleave]

          public Task<decimal> GetBalance()

          {

              return Task.FromResult(this.State.Balance);

          }

      }

      ESRepGrain

      ESGrain默认是主Actor,当单个Actor压力过大时,可以实现该actor的副本actor,副本actor主要用来处理:1.读的操作;2.其他非写的异步操作。

      主actor与副本actor之间保持同步的机制:
      1. 主actor引发事件,在CoreHandler里将消息传递给副本actor,在副本actor里面重放该事件。

      2. 主actor与副本actor持久化的是同一个快照库、事件库。也会从同一个库里激活。

      生命周期

      与主actor类似。

      使用

      与ESGrain类似,对比如下:

      ESGrainESRepGrain
      明确RabbitPub不需要
      明确MongoStorage明确MongoStorage
      继承MongoESGrain或SqlGrain继承MongoESRepGrain或SqlRepGrain
      实现ESGrain接口自定义的副本Actor接口
      如果需要重写OnActivateAsync如果需要重写OnActivateAsync
      编写感兴趣的Actor方法编写感兴趣的Actor方法
      如果需要发送事件:1.定义事件;2.编写EventHandler不会引发事件
      示例

      [MongoStorage("Test", "Account")]

      public sealed class AccountRep : MongoESRepGrain<String, AccountState, MessageInfo>, IAccountRep

      {

           protected override string GrainId => this.GetPrimaryKeyString();


           static IEventHandle _eventHandle = new AccountEventHandle();

           protected override IEventHandle EventHandle => _eventHandle;


           public Task<decimal> GetBalance()

           {

               return Task.FromResult(this.State.Balance);

           }

      }

      原文地址:http://www.cnblogs.com/CharlesZHENG/p/8438057.html


      .NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

      本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/322133.shtml

      如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

      相关文章

      DotNetAnywhere:可供选择的 .NET 运行时

      我最近在收听一个名为DotNetRock 的优质播客&#xff0c;其中有以Knockout.js而闻名的Steven Sanderson 正在讨论 " WebAssembly And Blazor "。也许你还没听过&#xff0c;Blazor 正试图凭借WebAssembly的魔力将 .NET 带入到浏览器中。如果您想了解更多信息&#xf…

      SpringCloud Greenwich(二)注册中心之consul、Zuul和 gateway网关配置

      本项目是搭建基于consul注册中心的springcloud&#xff0c;使用zuul网关和gateway网关 一、框架搭建 &#xff08;1&#xff09;项目结构 micro-service 服务提供者 zuul-gateway zuul网关 springcloud-gateway gateway网关 &#xff08;2&#xff09;环境 consul 1.9.0…

      Actor-ES框架:消息发布器与消息存储器

      消息发布器&#xff1a;Ray是基于Event Sourcing设计的ES/Actor框架&#xff0c;ESGrain状态&#xff08;State&#xff09;的修改、ESGrain之间的通信默认使用RabbitMQ通信。消息的发布器主要是RabbitPubESGrain。RabbitPub特性RabbitPub特性是RabbitMQ消息发布器。RabbitSub特…

      consul的安装搭建

      一、下载consul consul官网下载地址&#xff1a;https://www.consul.io/downloads 旧版本下载 consul 1.9.3直接下载地址&#xff1a; consul_1.9.3_windows_amd64.zip consul_1.9.3_linux_amd64.zip 二、安装 将consul_1.9.3_xxx.zip解压的xxx/consul目录 &#xff08;1&…

      使用xUnit为.net core程序进行单元测试

      一. 导读为什么要编写自动化测试程序&#xff08;Automated Tests&#xff09;&#xff1f;可以频繁的进行测试可以在任何时间进行测试&#xff0c;也可以按计划定时进行&#xff0c;例如&#xff1a;可以在半夜进行自动测试。肯定比人工测试要快。可以更快速的发现错误。基本上…

      jzoj6276-[Noip提高组模拟1]树【线段树,扫描线,倍增】

      正题 题目大意 一棵树&#xff0c;若干个点对&#xff0c;求不包括任何一个点对的路径数量。 解题思路 我们考虑将不合法的方案在坐标系上表示。 我们先只考虑一个点对(x,y)(x,y)(x,y)&#xff0c;若xxx和yyy没有祖先关系&#xff0c;则不合法的路径一个点在xxx的子树中&…

      SpringCloud Greenwich(三)注册中心之zookeeper、Zuul和 gateway网关配置

      本项目是搭建基于zookeeper注册中心的springcloud&#xff0c;使用zuul网关和gateway网关 一、框架搭建 &#xff08;1&#xff09;项目结构 micro-service 服务提供者 zuul-gateway zuul网关 springcloud-gateway gateway网关 &#xff08;2&#xff09;环境 zookeeper…

      Metrics, tracing 和 logging 的关系

      译者注Peter Bourgon原作&#xff1a; Metrics, tracing, and logging译者&#xff1a;吴晟原作发表时间&#xff1a; 2017年2月21日这是在OpenTracing和分布式追踪领域内广受欢迎的一篇博客文章。在构建监控系统时&#xff0c;大家往往在这几个名词和方式之间纠结。 通过这篇文…

      快速序列化组件MessagePack介绍

      简介MessagePack for C&#xff03;&#xff08;MessagePack-CSharp&#xff09;是用于C&#xff03;的极速MessagePack序列化程序&#xff0c;比MsgPack-Cli快10倍&#xff0c;与其他所有C&#xff03;序列化程序相比&#xff0c;具有最好的性能。 MessagePack for C&#xff…

      SpringCloud Greenwich(四)注册中心之eureka、Zuul和 gateway网关配置

      本项目是搭建基于eureka注册中心的springcloud&#xff0c;使用zuul网关和gateway网关 一、框架搭建 &#xff08;1&#xff09;项目结构 eureka-server eureka注册中心 micro-service 服务提供者 zuul-gateway zuul网关 springcloud-gateway gateway网关 &#xff08;…

      【ASP.NET Core】给路由规则命名有何用处

      上一篇中老周给伙伴们介绍了自定义视图搜索路径的方法&#xff0c;本篇咱们扯一下有关 URL 路径规则的名称问题。在扯今天的话题之前&#xff0c;先补充点东东。在上一篇中设置视图搜索路径时用到三个有序参数&#xff1a;{2}{1}{0}&#xff0c;分别是 Area、Controller、Actio…

      SpringCloud Greenwich(五)之nacos、dubbo、Zuul和 gateway集成

      本项目是搭建基于nacos注册中心的springcloud&#xff0c;集成dubbo框架&#xff0c;使用zuul网关和gateway网关 一、框架搭建 &#xff08;1&#xff09;项目结构 micro-service 服务提供者 zuul-gateway zuul网关 springcloud-gateway gateway网关 class-provider dubo…

      .NET/.NET Core中更清晰的堆栈跟踪

      在基于异常的语言中&#xff0c;堆栈跟踪是用于诊断问题最重要的工具之一。在某些情况下&#xff0c;开发人员能得到的仅为一条简短的错误信息以及堆栈跟踪&#xff0c;尤其是当个人可识别信息&#xff08;PII&#xff09;约束限制了日志记录的内容时。随着任务并行库&#xff…

      SpringCloud Greenwich(六)集成dubbo与openfeign的feignTargeter报错,cannot access its superinterface Targeter

      一、现象 org.springframework.beans.factory.BeanCreationException: Error creating bean with name feignTargeter defined in class path resource [org/springframework/cloud/openfeign/FeignAutoConfiguration$HystrixFeignTargeterConfiguration.class]: Initializati…

      一个开源的强类型客户端(.NET 中的 Open Fegin)— Rabbit Go

      在做RabbitCloud&#xff08;之前是一个RPC&#xff0c;现在是一个微服务框架&#xff09;的时候往往避不开客户端代理&#xff0c;之前把这些客户端代理都算作服务框架不可缺少的一部分&#xff0c;随着后期的深入发现这些客户端代理其实可以互通&#xff0c;类似spring cloud…

      SpringCloud Greenwich(七)集成dubbo先启动消费者(check=false),然后启动提供者无法自动发现注册

      SpringCloud Greenwich集成dubbo先启动消费者&#xff08;checkfalse&#xff09;&#xff0c;然后启动提供者无法自动发现注册问题。 官方说明&#xff1a;修复bug的提交时间 spring-cloud-starter-dubbo 2.2.4.RELEASE之前的版本都会有先启动消费者&#xff08;checkfalse&am…

      .NET Core 实现定时抓取博客园首页文章信息并发送到邮箱

      前言大家好&#xff0c;我是晓晨。许久没有更新博客了&#xff0c;今天给大家带来一篇干货型文章&#xff0c;一个每隔5分钟抓取博客园首页文章信息并在第二天的上午9点发送到你的邮箱的小工具。比如我在2018年2月14日&#xff0c;9点来到公司我就会收到一封邮件&#xff0c;是…

      Linux shell echo打印不出换行

      一、现象 echo打印不出换行 指令 ps aux | grep python ps aux | grep python | xargs echo 运行结果&#xff1a; 二、使用参数-e echo一样打印不出换行 ps aux | grep python | xargs echo -e 运行结果&#xff1a; 三、使用参数-e和双引号包裹占位符 echo终于可以…

      基于Citus和ASP.NET Core开发多租户应用

      Citus是基于PsotgreSQL的扩展&#xff0c;用于切分PsotgreSQL的数据&#xff0c;非常简单地实现数据“切片&#xff08;sharp&#xff09;”。如果不使用Citus&#xff0c;则需要开发者自己实现分布式数据访问层&#xff08;DDAL&#xff09;&#xff0c;实现路由和结果汇总等逻…

      ASP.NET CORE 微服务(简化版)实战系列-没有比这性价比再高的实战课程了

      ASP.NET CORE 微服务(简化版&#xff09;实战系列&#xff0c;最后1天298&#xff0c;现在注册购买再减50。作者jesse 腾飞在2.14 早上我买了他的课程后&#xff0c;他才做了下面这个活动&#xff1a;作者jesse 腾飞花了大量的时间做了一个非常好的视频教程&#xff0c;我个人也…