当前位置: 首页 > news >正文

Orleans 客户端与 Silo 配置方式深度分析

概述

本文档深入分析 Orleans 中两种主要配置方式的区别:

  1. UseOrleansClient - 客户端配置
  2. UseOrleans - Silo 服务器配置

核心区别

1. 架构角色差异

UseOrleansClient (客户端配置)
using var host = Host.CreateDefaultBuilder(args).UseOrleansClient(clientBuilder =>clientBuilder.UseLocalhostClustering()).Build();

特点:

  • 创建 Orleans 客户端,用于连接到 Orleans 集群
  • 只能调用 Grain 方法,不能承载 Grain 实例
  • 轻量级,资源消耗少
  • 适用于客户端应用程序、Web API、控制台应用等
UseOrleans (Silo 配置)
using var host = Host.CreateDefaultBuilder(args).UseOrleans(siloBuilder =>{siloBuilder.UseLocalhostClustering();}).Build();

特点:

  • 创建 Orleans Silo,作为集群节点运行
  • 可以承载和执行业务 Grain
  • 包含完整的 Orleans 运行时
  • 适用于服务器端应用程序

源码分析

UseOrleansClient 实现

位置: src/Orleans.Core/Hosting/OrleansClientGenericHostExtensions.cs

public static IHostBuilder UseOrleansClient(this IHostBuilder hostBuilder,Action<HostBuilderContext, IClientBuilder> configureDelegate)
{// 检查是否已配置 Siloif (hostBuilder.Properties.ContainsKey("HasOrleansSiloBuilder")){throw GetOrleansSiloAddedException();}hostBuilder.Properties["HasOrleansClientBuilder"] = "true";return hostBuilder.ConfigureServices((ctx, services) => configureDelegate(ctx, AddOrleansClient(services, ctx.Configuration)));
}

关键点:

  • 设置 "HasOrleansClientBuilder" 标记
  • 检查是否已配置 Silo(互斥性)
  • 创建 ClientBuilder 实例

UseOrleans 实现

位置: src/Orleans.Runtime/Hosting/OrleansSiloGenericHostExtensions.cs

public static IHostBuilder UseOrleans(this IHostBuilder hostBuilder,Action<HostBuilderContext, ISiloBuilder> configureDelegate)
{// 检查是否已配置客户端if (hostBuilder.Properties.ContainsKey("HasOrleansClientBuilder")){throw GetOrleansClientAddedException();}hostBuilder.Properties["HasOrleansSiloBuilder"] = "true";return hostBuilder.ConfigureServices((context, services) => configureDelegate(context, AddOrleansCore(services, context.Configuration)));
}

关键点:

  • 设置 "HasOrleansSiloBuilder" 标记
  • 检查是否已配置客户端(互斥性)
  • 创建 SiloBuilder 实例

Builder 类对比

ClientBuilder
public class ClientBuilder : IClientBuilder
{public ClientBuilder(IServiceCollection services, IConfiguration configuration){Services = services;Configuration = configuration;DefaultClientServices.AddDefaultServices(this);  // 添加客户端默认服务}
}
SiloBuilder
internal class SiloBuilder : ISiloBuilder
{public SiloBuilder(IServiceCollection services, IConfiguration configuration){Services = services;Configuration = configuration;DefaultSiloServices.AddDefaultServices(this);   // 添加 Silo 默认服务}
}

服务注册差异

客户端服务 (DefaultClientServices)

  • IClusterClient - 集群客户端接口
  • ClientMessageCenter - 客户端消息中心
  • ConnectionManager - 连接管理器
  • 序列化服务
  • 日志服务

Silo 服务 (DefaultSiloServices)

  • 所有客户端服务
  • Silo - Silo 运行时实例
  • Catalog - Grain 目录
  • LocalGrainDirectory - 本地 Grain 目录
  • MessageCenter - 消息中心
  • MembershipService - 成员服务
  • 存储提供程序
  • 流提供程序

UseLocalhostClustering 实现差异

客户端版本

public static IClientBuilder UseLocalhostClustering(this IClientBuilder builder,int gatewayPort = 30000,string serviceId = ClusterOptions.DevelopmentServiceId,string clusterId = ClusterOptions.DevelopmentClusterId)
{return builder.UseLocalhostClustering(new [] {gatewayPort}, serviceId, clusterId);
}

配置内容:

  • 静态集群配置
  • 网关端口配置
  • 服务 ID 和集群 ID

Silo 版本

public static ISiloBuilder UseLocalhostClustering(this ISiloBuilder builder,int siloPort = EndpointOptions.DEFAULT_SILO_PORT,int gatewayPort = EndpointOptions.DEFAULT_GATEWAY_PORT,IPEndPoint primarySiloEndpoint = null,string serviceId = ClusterOptions.DevelopmentServiceId,string clusterId = ClusterOptions.DevelopmentClusterId)
{builder.Configure<EndpointOptions>(options =>{options.AdvertisedIPAddress = IPAddress.Loopback;options.SiloPort = siloPort;options.GatewayPort = gatewayPort;});builder.UseDevelopmentClustering(optionsBuilder => ConfigurePrimarySiloEndpoint(optionsBuilder, primarySiloEndpoint));
}

配置内容:

  • Silo 端口和网关端口
  • 端点选项配置
  • 开发集群配置
  • 主 Silo 端点配置

运行时行为差异

客户端运行时

  1. 连接阶段: 连接到集群网关
  2. 服务发现: 获取可用 Silo 列表
  3. Grain 调用: 通过网关路由到目标 Silo
  4. 生命周期: 轻量级,快速启动/停止

Silo 运行时

  1. 初始化阶段: 启动完整的 Orleans 运行时
  2. 成员管理: 参与集群成员协议
  3. Grain 承载: 执行和承载业务 Grain
  4. 消息处理: 处理来自客户端和其他 Silo 的消息
  5. 生命周期: 重量级,启动时间较长

使用场景

UseOrleansClient 适用场景

  • Web API 应用: 作为客户端调用 Orleans 服务
  • 控制台应用: 批处理、定时任务
  • 桌面应用: 客户端应用程序
  • 微服务: 需要调用 Orleans 集群的服务

UseOrleans 适用场景

  • 业务服务: 承载核心业务逻辑
  • 数据处理服务: 大数据处理、ETL
  • 游戏服务器: 游戏逻辑处理
  • 实时系统: 需要状态管理的应用

互斥性检查

Orleans 框架通过以下机制确保配置的互斥性:

// 客户端配置检查
if (hostBuilder.Properties.ContainsKey("HasOrleansSiloBuilder"))
{throw GetOrleansSiloAddedException();
}// Silo 配置检查
if (hostBuilder.Properties.ContainsKey("HasOrleansClientBuilder"))
{throw GetOrleansClientAddedException();
}

错误信息:

  • 客户端配置时:"Do not call both UseOrleansClient/AddOrleansClient with UseOrleans/AddOrleans..."
  • Silo 配置时:类似的互斥性错误

性能对比

特性UseOrleansClientUseOrleans
启动时间快 (< 1秒)慢 (2-5秒)
内存占用低 (10-50MB)高 (100-500MB)
CPU 使用中等
网络连接仅出站入站+出站
存储需求可能需要持久化存储

最佳实践

1. 架构设计

  • 客户端应用: 使用 UseOrleansClient
  • 服务端应用: 使用 UseOrleans
  • 混合应用: 避免在同一进程中同时使用

2. 配置管理

// 客户端配置示例
var clientHost = Host.CreateDefaultBuilder(args).UseOrleansClient(clientBuilder =>{clientBuilder.UseLocalhostClustering().ConfigureLogging(logging => logging.AddConsole());}).Build();// Silo 配置示例
var siloHost = Host.CreateDefaultBuilder(args).UseOrleans(siloBuilder =>{siloBuilder.UseLocalhostClustering().AddMemoryGrainStorage("Default").ConfigureLogging(logging => logging.AddConsole());}).Build();

3. 错误处理

  • 始终检查配置的互斥性
  • 使用适当的异常处理
  • 监控启动和运行状态

总结

UseOrleansClientUseOrleans 是 Orleans 框架中两种不同的配置方式,分别对应客户端和服务器端的角色。它们在架构设计、服务注册、运行时行为等方面存在显著差异。正确选择和使用这两种配置方式对于构建高性能、可扩展的分布式应用程序至关重要。

通过源码分析可以看出,Orleans 框架通过严格的互斥性检查和不同的服务注册机制,确保了配置的正确性和系统的稳定性。开发者应该根据应用的具体需求选择合适的配置方式。

http://www.dtcms.com/a/525265.html

相关文章:

  • RecyclerView设置空布局
  • 如何看网站空间问题开发网站公司
  • 广州网站设计开发招聘泰兴中信建设有限责任公司
  • 石家庄seo网站建设云南省科技网站
  • 基于单片机的恒流源三极管放大倍数测量仪设计
  • 如何解除 iPad 和 iPhone 文本消息的关联?
  • 乔智云智能建站软件开发培训视频
  • 网站建设有哪些推广渠道做违法网站会怎么样
  • 多少钱算网站常州网站建设哪家便宜
  • 郑州企业网站建设费用策划公司起什么名字好
  • KTH1701 系列高性能、低功耗、全极磁场检测霍尔开关传感器
  • LeeCode 143. 重排链表
  • 1024节日?
  • 云图-地基云图-云层分割
  • 网上做论文的网站c网站开发
  • 递归|模拟
  • 站长之家统计广告设计制作税率
  • Linux环境下编译C语言使用libpq连接瀚高数据库
  • 门户网站排行榜seo实战密码第四版电子书
  • 购物网站哪个好电商网站营销
  • HBase基础命令详解
  • 租好服务器咋做网站呢网页设计与网站制作视频教程
  • 上海网站制作网络推广方法网站优化塔山双喜
  • 学习如何用 C++ 写一个线程安全的单例模式
  • 使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 21--PO(POM) 设计模式代码实现和全局浏览器驱动设置
  • 旋转花键如何实现微米级定位误差控制?
  • 提供手机自适应网站公司用易语言做钓鱼网站
  • 网站后台是怎么更新跨境电商平台有哪些特点
  • UVa 12991 Game Rooms
  • 2012年下半年试题一:论基于架构的软件设计方法及应用