Orleans 知多少 | 2. 核心概念一览

Orleans 术语解读

640?wx_fmt=png

上面这张图中包含了Orleans中的几个核心概念:

  1. Grain

  2. Silo

  3. Orleans Cluster

  4. Orleans Client

从这张图,我们应该能理清他们之间的关系。

  1. Grain作为最小的执行单元

  2. Silo 是 Grain 的宿主运行环境,用来暴露具体的服务

  3. Orleans Server 提供Silo的运行环境

  4. 一个Server可以运行多个Silo服务

  5. 多个Silo组成一个Cluster集群

  6. 一个Cluster中的Grain是可以直接进行交互

  7. 客户端通过Orleans Client与Cluster建立连接

Orleans 的第一公民:Grain

Grain 简介

上面已经提到,Grain是Virtual Actor的具体表现。那如何理解Grain呢。

简单来说:Grain是一个可寻址的隔离的.NET对象实例

分解来看:

  1. Grain是一个对象实例:也就是说其是具体的某个Grain Type的一个内存实例。既然是对象,也就是说Grain可以有自己的状态和行为。

  2. 隔离的:是指Grain自身的状态和行为不受外界干预。

  3. 可寻址:并不是指new一个对象返回的内存引用。如果是在单机环境,通过内存引用还可以进行直接访问。但对于分布式应用,Grain可能分布在集群中的任一机器,简单的内存引用,是无法实现跨机器寻址的。

Grain Identity

在面向对象编程中使用new创建对象时,获取的引用可以表示其标识的实例所有方面。但在分布式系统中,对象引用不能表示实例标识,因为引用通常仅限于单个地址空间。

那如何实现分布式环境Grain的可寻址呢?

那就需要给Grain一个身份,也就是Grain Identity。以订单举例,为了标识某一个具体订单,我可以赋予订单一个唯一的订单编号,通过这个编号就可以找到具体的某个订单。

Grain Identity 也就是这种思路。通过给Grain打上逻辑身份标识,一方面可以完成可寻址(方便其他Grain或Client进行调用),一方面确保同一个Grain在集群中能够按需创建。(单例、多例、指定数量的实例)。

默认grain 的身份标识可以是:

  • long

  • GUID

  • string

  • GUID + string

  • long + string

所以基于GrainType和Grain Identity就可以得到集群中唯一确定的Grain。即 Unique Grain = Grain Type + Grain Identity

Grain Lifecycle

Grain 的生命周期是由Silo管理的。主要分为以下几个阶段:

640?wx_fmt=png

  • 其他Grain或Client调用目标Grain

  • Silo运行时去激活Grain (若Grain是有状态的,激活时会同时恢复状态)

  • Grain处理调用请求

  • Grain闲置

  • Silo运行时决定是否销毁Grain

  • 销毁Grain,从内存中移除(若Grain是有状态的,则需要先持久化Grain的状态,以便下次激活时恢复状态)

Grain的运行环境:Silo

Grain作为Orleans中的最小执行单元,需要一个运行环境运行以暴露服务,而Silo就是这样一个角色存在。如果说Grain是最小粒度的执行单元,那么Silo就是最小的向外提供服务的执行单元。Silo通过将相关Grain进行组装,暴露一组服务,并在运行时管理Grain的生命周期。

Silo的宿主:Orleans Server

Silo本质上是一个进程单元,是需要运行在操作系统之上的,因为.NET Core的跨平台特性,所以可以运行在Windows、Linux或Mac系统中,当然也可以运行在相应的容器中。所以Orleans Server就是为Silo提供运行环境的宿主。

Silo的集群:Orleans Cluster

这里需要澄清一点,因为一个Orleans Server可以运行不同集群的Silo,所以Orleans Cluster 并非是指多个Orleans Server 组成的集群,而是指多个Silo(具有相同的ClusterId)组成的集群。Orleans通过内置的成员协议提供集群管理,我们有时将其称为Silo Membership。该协议的目标是让所有Silo(Orleans Server)就当前活动的Silo集合达成一致,检测故障Silo,并允许新的Silo加入集群。

640?wx_fmt=png


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

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

相关文章

动手造轮子:实现一个简单的 EventBus

动手造轮子:实现一个简单的 EventBusIntroEventBus 是一种事件发布订阅模式,通过 EventBus 我们可以很方便的实现解耦,将事件的发起和事件的处理的很好的分隔开来,很好的实现解耦。微软官方的示例项目 EShopOnContainers 也有在使…

通过 nginx-proxy 实现自动反向代理和 HTTPS

本章节代码已经上传至 https://github.com/siegrainwong/.NET-Core-with-Docker/tree/master/Part3系列大纲这次我们讲第三篇:用 docker-compose 启动 WebApi 和 SQL Server在容器中集成 Skywalking APM通过 nginx-proxy 对 Portainer、Skywalking、WebApi 实现自动…

P4781 【模板】拉格朗日插值

传送门 把公式实现一下即可: 当xxx连续的时候可以优化为O(N)O(N)O(N)。 // Problem: P4781 【模板】拉格朗日插值 // Contest: Luogu // URL: https://www.luogu.com.cn/problem/P4781 // Memory Limit: 125 MB // Time Limit: 1000 ms // // Powered by CP Edi…

MediatR-进程内的消息通信框架

MediatR是一款进程内的消息订阅、发布框架,提供了Send方法用于发布到单个处理程序、Publish方法发布到多个处理程序,使用起来非常方便。目前支持 .NET Framework4.5、.NET Stardand1.3、.NET Stardand2.0等版本,可跨平台使用。要在项目中使用…

不好意思,这么久没有更新《从零开始掌握ASP.NET Core 》

点击上方蓝字,关注「我们」等了快个月了,终于开始更新了。因为感冒,弄的嗓子有点沙哑。所以停了半个月才是更新,目前一口气更新了12个章节,大家可以耐心观看内容了。《从零开始学ASP.NET Core 》-- 更新通知视频课程更…

使用Azure云原生构建博客是怎样一种体验?(下篇)

点击上方蓝字关注“汪宇杰博客”接上篇《使用Azure云原生构建博客是怎样一种体验?(上篇)》DNSAzure DNS 是一套分布全球的域名解析服务。具有超高可用性和接近实时的记录更新及生效速度。我的博客也使用了这项服务。Azure 现在可以提供域名注…

2021牛客暑期多校训练营1 G Game of Swapping Numbers 思维 + 巧妙的转换

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个数组A,BA,BA,B&#xff0c;你可以选择AAA的两个位置i,j,i<ji,j,i<ji,j,i<j交换Ai,AjA_i,A_jAi​,Aj​&#xff0c;需要交换正好kkk次&#xff0c;问你最大的∑i1n∣Ai−Bi∣\sum_{i1}^n|A_…

.NET Core 3.0之深入源码理解HttpClientFactory(一)

写在前面创建HttpClient实例的时候&#xff0c;在内部会创建HttpMessageHandler链&#xff0c;我们知道HttpMessageHandler是负责建立连接的抽象处理程序&#xff0c;所以HttpClient的维护实际上就是维护HttpMessageHandler的使用&#xff0c;释放HttpClient并不会及时释放连接…

WTM 构建DotNetCore开源生态,坐而论道不如起而行之

作为一个8岁开始学习编程&#xff0c;至今40岁的老程序员&#xff0c;这辈子使用过无数种语言&#xff0c;从basic开始&#xff0c;到pascal, C, C&#xff0c;到后来的 java, c#,perl,php,再到现在流行的python。小时候的我总觉得多掌握一门语言&#xff0c;我的技术能力就又前…

架构杂谈《六》

超时处理模式在服务化或者微服务架构里&#xff0c;传统的整体应用拆分成多个职责单一的微服务&#xff0c;微服务之间通过某种网络通信协议互相通信和交互&#xff0c;完成特定的功能&#xff0c;然而由于网络通信的不稳定&#xff0c;在设计系统时必须考虑到对网络通信的容错…

【BZOJ4543】Hotel加强版【神仙树形dp】【长链剖分】

题意&#xff1a;给一棵 nnn 个点的树&#xff0c;求两两距离相等的三元组个数。 n≤105n\leq 10^5n≤105 显然相当于是找一个点到这三个点距离相等。子树内和子树外到当前点的距离为某个值的点的个数可以长链剖分快速得到&#xff0c;但统计答案非常棘手。 接下来是个鬼才想…

基于surging 的stage组件设计,谈谈我眼中的微服务

一、前言surging 开源地址&#xff1a;https://github.com/dotnetcore/surging随着业务的发展&#xff0c;并发量的增多&#xff0c;业务的复杂度越来越大&#xff0c;对于系统架构能力要求越来越高&#xff0c;这时候微服务的设计思想应运而生&#xff0c;但是对于微服务需要引…

HDU - 6971 K - I love max and multiply sosdp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 直接求i&j>ki\And j>ki&j>k不是很好求&#xff0c;所以转换成i&jki\And jki&jk的情况。 考虑对a,ba,ba,b求一遍超集&#xff0c;让后从[0,n−1][0,n-1][0,n−1]扫…

推荐10个技术圈优质的公众号大号

公众号有很多但需要什么只有自己知道本次筛选了一批技术圈优质的公众号&#xff0c;主要与python、人工智能、机器学习、技术人生相关希望对你有所帮助!▼★长按二维码&#xff0c;选择“识别二维码”进行关注。▲长按二维码&#xff0c;识别关注简介&#xff1a;Python爱好者社…

使用Kubeadm创建k8s集群之部署规划(三十一)

前言 上一篇我们讲述了使用Kubectl管理k8s集群&#xff0c;那么接下来&#xff0c;我们将使用kubeadm来启动k8s集群。部署k8s集群存在一定的挑战&#xff0c;尤其是部署高可用的k8s集群更是颇为复杂&#xff08;后续会讲&#xff09;。因此本教程会在部署的过程中穿插讲…

HDU - 6967 G I love data structure 线段树维护矩阵 + 细节

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个长度为nnn的数组a,ba,ba,b&#xff0c;你需要完成如下四种操作&#xff1a; 思路&#xff1a; 思路还是比较简单的&#xff0c;首先建一颗线段树&#xff0c;线段树中维护a,b,a2,b2,aba,b,a^2,b^…

荐读|属性与可直接访问的数据成员之间应该如何选

写在前面在书写C#代码的时候你是否有过这样的经历&#xff1a;经常混用属性以及公有的数据成员。毕竟他们的用法基本一致&#xff0c;对于使用来说好像没什么区别啊。其实我也经常使用类的公有的数据成员来定义一些常量&#xff0c;为了简单&#xff0c;在一些仅仅需要对外暴露…

2021牛客暑期多校训练营3 I Kuriyama Mirai and Exclusive Or 差分 + 二进制分治

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组aaa&#xff0c;让你实现以下两个操作之后输出数组aaa。 n≤6e5,ai≤230−1n\le6e5,a_i\le2^{30}-1n≤6e5,ai​≤230−1 思路&#xff1a; 下面介绍的思路清奇&#xff0c;反正我想不到。 对…

Lock VS Monitor

介绍介绍对开发人员来说&#xff0c;处理关键代码部分的多线程应用程序是非常重要的。Monitor和lock是c#语言中多线程应用程序中提供线程安全的方法(lock关键字的本质就是对Monitor的封装)。两者都提供了一种机制来确保只有一个线程同时执行代码&#xff0c;以避免代码功能被其…

程序员修神之路--做好分库分表其实很难之二

菜菜哥&#xff0c;上次听你给我讲了分库的情况后&#xff0c;我明白了很多&#xff0c;能再给我讲讲分表吗有收获就好&#xff0c;分表其实有很多情况和分库类似还有不一样的情况吗&#xff1f;有呀&#xff0c;本来数据库和表是不同层面的东西&#xff0c;肯定有差异那你给讲…