- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在研究 Orleans 作为 Asp.net core Web api 项目的后端,并且想知道是否有人对其新功能“直接客户端”有任何经验。奥尔良文档说“它允许共同托管客户端和筒仓,让客户端不仅可以与它所连接的筒仓进行更有效的通信,还可以与整个集群进行更有效的通信”,我知道您可以编写类似这样的代码(并且它在控制台应用程序中运行得很好):
var silo = new SiloHostBuilder()
.UseLocalhostClustering()
.EnableDirectClient()
.Build();
await silo.StartAsync();
var client = silo.Services.GetRequiredService<IClusterClient>();
我正在努力找出在“Main”中拥有自己的网络主机构建器的 asp.net 项目中的何处放置此类代码(应该转到“ConfigureServices”中的 Startup 类吗?)。最后,我们的目标是单独的客户端/服务器设置,但为了更快的开发,使用简单的设置会很有用,直接客户端似乎允许这样做。任何指向包含 ASP.NET Core 直接客户端的资源和/或示例解决方案的指针将不胜感激。谢谢。
编辑:这是现在对我有用的代码,但我对 DI 的设置方式不满意
public static async Task Main(string[] args)
{
var silo = new SiloHostBuilder()
.UseLocalhostClustering()
.ConfigureServices(services =>
{
services.AddDbContext<UserDbSet>(o => o.UseSqlite("Data Source=UserTest.db"));
services.AddMediatR(typeof(Startup).Assembly);
})
.EnableDirectClient()
.Build();
await silo.StartAsync();
var client = silo.Services.GetRequiredService<IClusterClient>();
await WebHost.CreateDefaultBuilder(args)
.UseConfiguration(new ConfigurationBuilder()
.AddCommandLine(args)
.Build())
.ConfigureServices(services =>
services
.AddSingleton<IGrainFactory>(client)
.AddSingleton<IClusterClient>(client))
.UseStartup<Startup>()
.Build()
.RunAsync();
}
如果我将 DbContext
和 Mediatr
的注册放在 StartUp
类中,grain 代码会失败,并出现异常,指示无法实例化所需的内容依赖关系。也许我在设置Webhost
时做错了什么?
最佳答案
对于 ASP.NET 2.x 和低于 2.3 的 Orleans,我建议在 Web 主机之前创建并启动筒仓。配置 Web 主机时,从 silo 注入(inject) IGrainFactory
和 IClusterClient
实例(通过 silo.Services
获取):
var silo = new SiloHostBuilder()
.UseLocalhostClustering()
.EnableDirectClient()
.Build();
await silo.StartAsync();
var client = silo.Services.GetRequiredService<IClusterClient>();
var webHost = new WebHostBuilder()
.ConfigureServices(services =>
services
.AddSingleton<IGrainFactory>(client)
.AddSingleton<IClusterClient>(client))
.UseStartup<Startup>()
// Other ASP.NET configuration...
.Build();
对于 ASP.NET 3.0 和 Orleans 2.3 或更高版本,由于在两个框架中添加了 Microsoft.Extensions.Hosting
支持,集成代码变得更加简单:
var host = new HostBuilder()
.ConfigureWebHost(builder =>
{
// Adding IGrainFactory, etc, is not necessary, since Orleans
// and ASP.NET share the same dependency injection container.
builder.UseStartup<Startup>();
})
.UseOrleans(builder =>
{
// EnableDirectClient is no longer needed as it is enabled by default
builder.UseLocalhostClustering();
})
.Build();
await host.StartAsync();
关于ASP.NET Core 项目中的 Orleans 直接客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54841844/
如何检查某个特定 ID 的grain是否已经存在? 考虑到下面将使用我传递给 GetGrain() 的 Id 创建一个新的玩家 Grain(如果它不存在),我不知道如何检查是否已经存在。 public
文档中有几个令人困惑的地方,让我很难理解在 Orleans 中跨集群的分布究竟是如何发生的。因此,问题。 问题#1 Orleans 声称有一个内置的 distribution跨多个服务器分布的能力。在
如果在同一个grain activation上有两个不同的reminders在同一个点触发,假设grain execution context是单线程的,两个reminders会同时执行和交错吗? 另
我有一个在 OnActivate 方法中设置提醒的 grain。然后,提醒会定期执行一些操作,并且不需要从筒仓外部进行进一步的通信。 是否有可能在主机启动期间获取 GrainProvider 并在主机
我已阅读奥尔良常见问题解答,了解何时可能发生裂脑,但我不明白会发生什么不良情况以及如何正确处理。 常见问题解答说了一些模糊的内容,例如: You just need to consider the r
如果在同一个grain activation上有两个不同的reminders在同一个点触发,假设grain execution context是单线程的,两个reminders会同时执行和交错吗? 另
如果我有一个 grain(或客户端)要经常向另一个 grain 发送消息(每分钟几次,持续几个小时),访问该 grain 的最佳实践是什么?我是从工厂拿到它,使用它,然后丢弃它——每次都获得一个新的
我正在尝试为使用 SQL Server 的 Orleans 设置一个测试环境。这是我的服务器配置文件: -->
Microsoft Orleans 框架提供了一种无需太多复杂性即可构建分布式、大规模系统的方法。 缩放对于奥尔良来说是自然的;如果主机出现故障,则该主机上的事件颗粒会在其他地方重新激活,因为它们的状
组织提醒 + 计时器的最佳方式是什么? 我想在一秒钟内精确地运行一个任务。 据我所知,我需要每隔一段时间运行一次提醒。并且每次开始间隔都会触发一个计时器以达到特定时间。但是我应该指定哪个提醒间隔来实现
我正在测试 Microsoft Orleans作为分布式计算框架的可行性。似乎它可以工作,但我想知道如何设置给定筒仓中的最大事件 Cereal 数? 我的 grain 不会纯粹受 CPU 限制,而是会
我参与了一个 IoT 项目并考虑将 orleans 作为一个平台。我试着在这里做基本教程: http://dotnet.github.io/orleans/Step-by-step-Tutorials
我需要一个 reader-writer grain(s?) 来保存一些值,以便系统的其他部分可以频繁地并行引用它们。 我所追求的是存储一些系统范围的配置值,这些值经常被访问,并且可能会发生变化,但很少
我有三个 Cereal (A、B 和 C)在管道中执行不同的工作。 GrainA 将结果传递给 grainB,grainB 将结果传递给 grainC。我想保证可以通过下面实现的连续 Cereal 之
我正在尝试了解 Microsoft Orleans 中的单线程 grains。我使用了 here 中的代码并对其进行了一些修改以测试我的场景。 我的客户端代码和筒仓构建代码 static as
我正在尝试确定 Microsoft Orleans 的正确架构。我需要从大约 1000 个系统中检索 100 万到 300 万个文件,并将它们存储在几个中央服务器上。系统还将检索和存储每个文件的一些元
我不确定如何或在何处将依赖项注入(inject) Grain。最好的地方在哪里? 如果不可能,我是否应该在 WorkerRole.Run 方法中设置一个容器并在需要时获取实例? 最佳答案 从 orle
在 Microsoft Orleans 中,是否应该只有一个孤岛,因此每台机器只有一个主机进程?每台机器是否可以有多个孤岛/主机进程,并且每台主机有多个孤岛是否有任何可扩展性优势?是否有关于每台机器的
我正在使用 Mircosoft Orleans 作为基础开发工作流引擎,因为它提供了许多有用的功能,例如自动分配工作和处理故障转移。 我有三种 Cereal : 工作流 - 保存工作流中的信息以及工作
我正在制作一个应用程序作为一种学习体验,我遇到了两个主要问题: 1) 我的实现可能对奥尔良来说是个好主意,也可能不是……我只是不知道。 2) 我正在寻找有关托管和部署的建议,基本上是:在哪里以及如何?
我是一名优秀的程序员,十分优秀!