Orleans 2.0 官方文档 —— 6.1 部署 -> 运行程序

Orleans应用程序

典型的Orleans应用程序,由一组Grain所在的服务器进程(silo)和一组客户端进程(通常是Web服务器)组成。客户端进程接收外部请求,将它们转换为grain方法调用,然后返回结果。因此,运行Orleans应用程序需要做的第一件事就是启动一个silo集群。出于测试目的,集群可以由单个silo组成。为了实现可靠的生产部署,我们显然希望集群中有多个silo用于容错和扩展。

一旦集群启动后,我们可以启动一个或多个连接到集群的客户端进程,并可以向grain发送请求。客户端连接到silo上的一个特殊的TCP端点(称为网关)。默认情况下,集群中的每个silo都启用了客户端网关。因此,客户可以并行连接所有silo,以获得更好的性能和弹性。

配置和启动silo

silo通过ClusterConfiguration对象,以编程的方式配置。它可以从文件加载设置,直接被实例化和填充,或者使用一些可用的帮助方法对不同的部署环境来创建。对于本地测试,最简单的方法是使用ClusterConfiguration.LocalhostPrimarySilo()帮助方法。然后将配置对象传递给SiloHost类的一个新实例,然后初始化并启动该实例。

您可以创建一个空控制台应用程序项目,目标是.NET Framework 4.6.1或更高版本,来承载一个silo。将Microsoft.Orleans.ServerNuGet元数据包添加到项目中。

PM> Install-Package Microsoft.Orleans.Server

以下是如何启动本地silo的示例:

var siloConfig = ClusterConfiguration.LocalhostPrimarySilo(); 
var silo = new SiloHost("Test Silo", siloConfig); 
silo.InitializeOrleansSilo(); 
silo.StartOrleansSilo();

Console.WriteLine("Press Enter to close."); 
// wait here
Console.ReadLine(); 

// shut the silo down after we are done.
silo.ShutdownOrleansSilo();

配置和连接客户端

通过ClientConfiguration对象和一个ClientBuilder,以编程的方式,配置用于连接到silo集群并向grain发送请求的客户端。 ClientConfiguration对象可以从文件加载设置,直接实例化和填充,或者使用一些可用的帮助方法对不同的部署环境来创建。对于本地测试,最简单的方法是使用ClientConfiguration.LocalhostSilo()帮助方法。然后将配置对象传递给ClientBuilder类的新实例。

ClientBuilder公开了更多的方法,用来配置客户端功能。然后,调用ClientBuilder对象的Build方法,来获得一个IClusterClient接口的实现。最后,我们在返回的对象上调用Connect()方法,来连接到集群。

您可以创建一个面向.NET Framework 4.6.1或更高版本的空控制台应用程序项目,以运行客户端,或重用您为承载silo而创建的控制台应用程序项目。将Microsoft.Orleans.ClientNuGet元数据包添加到项目中。

PM> Install-Package Microsoft.Orleans.Client

以下是客户端如何连接到本地silo的示例:

var config = ClientConfiguration.LocalhostSilo();
var builder = new ClientBuilder().UseConfiguration(config).
var client = builder.Build();
await client.Connect();

生产配置

我们在这里使用的配置示例,用于测试在同一台机器(localhost)上运行的silo和客户端。在生产中,silo和客户端通常在不同的服务器上运行,并使用可靠的集群配置选项之一进行配置。您可以在“配置指南”(../ clusters_and_clients / configuration_guide / index.md)和“ 集群管理”的说明中找到有关该内容的更多信息。

  •  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自动控制节水灌溉技术的高低代表着农业现代化的发展状况,灌溉系统自动化水平较低是制约我国高效农业发展的主要原因。本文就此问题研究了单片机控制的滴灌节水灌溉系统,该系统可对不同土壤的湿度进行监控,并按照作物对土壤湿度的要求进行适时、适量灌水,其核心是单片机和PC机构成的控制部分,主要对土壤湿度与灌水量之间的关系、灌溉控制技术及设备系统的硬件、软件编程各个部分进行了深入的研究。 单片机控制部分采用上下位机的形式。下位机硬件部分选用AT89C51单片机为核心,主要由土壤湿度传感器,信号处理电路,显示电路,输出控制电路,故障报警电路等组成,软件选用汇编语言编程。上位机选用586型以上PC机,通过MAX232芯片实现同下位机的电平转换功能,上下位机之间通过串行通信方式进行数据的双向传输,软件选用VB高级编程语言以建立友好的人机界面。系统主要具有以下功能:可在PC机提供的人机对话界面上设置作物要求的土壤湿度相关参数;单片机可将土壤湿度传感器检测到的土壤湿度模拟量转换成数字量,显示于LED显示器上,同时单片机可采用串行通信方式将此湿度值传输到PC机上;PC机通过其内设程序计算出所需的灌水量和灌水时间,且显示于界面上,并将有关的灌水信息反馈给单片机,若需灌水,则单片机系统启动鸣音报警,发出灌水信号,并经放大驱动设备,开启电磁阀进行倒计时定时灌水,若不需灌水,即PC机上显示的灌水量和灌水时间均为0,系统不进行灌水。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值