Orleans是微软开源的.NET分布式框架,以“虚拟Actor”简化开发:本地双控制台即可运行Hello World集群,定义继承Grain的接口类实现远程调用,客户端通过GetGrain获取句柄像调用本地对象一样await执行,框架自动激活、路由、回收Grain实例。

Orleans 是微软开源的 .NET 分布式框架,核心思想是用“虚拟 Actor”简化分布式系统开发——你不用管实例在哪、是否存活、如何扩缩容,框架自动帮你调度、激活、回收。入门关键不是学一堆概念,而是跑通一个最简可运行的“Hello World”集群,并理解它怎么把代码变成跨进程/跨机器的自动伸缩服务。
1. 从一个控制台项目开始(无 Azure,无 Docker)
新手最容易卡在环境搭建。Orleans 不强制依赖云或容器,本地两个控制台程序就能模拟集群:
- 建一个 SiloHost 项目(服务端),引用
Microsoft.Orleans.Hosting和Microsoft.Orleans.Server - 建一个 ClientApp 项目(客户端),引用
Microsoft.Orleans.Client - Silo 启动时监听本地端口(如
11111),Client 连这个地址即可通信——不需要配置 ZooKeeper 或 Redis 做集群协调,内存版集群(LocalhostClustering)默认可用
2. 定义你的第一个 Grain(Actor)
Grain 是 Orleans 的核心单元,本质是一个有唯一 ID、带状态、可远程调用的类。它不是普通类,必须遵守几条轻量约束:
- 继承
Grain,实现一个接口(如IHelloGrain),接口需标记[GenerateSerializer](.NET 6+ 可用源生成器省略) - 方法必须是
public async Task<t></t>,不能有同步阻塞调用 - 状态存在
GrainStorage(默认内存,上线后建议配 SQL Server 或 Azure Table) - 示例:一个计数器 Grain,每次调用
SayHello(name)就自增并返回问候语 + 当前次数
3. 调用 Grain 就像调用本地对象
Client 不需要知道 Grain 在哪个进程、哪台机器上。你只拿一个泛型句柄:var grain = client.GetGrain<ihellograin>("user123");</ihellograin>,然后直接 await 调用:
string result = await grain.SayHello("Alice"); // 框架自动激活 Grain、路由请求、序列化结果
标签: redis docker app 端口 ai 路由 microsoft 微软 .net red
还木有评论哦,快来抢沙发吧~