- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试确定 Microsoft Orleans 的正确架构。我需要从大约 1000 个系统中检索 100 万到 300 万个文件,并将它们存储在几个中央服务器上。系统还将检索和存储每个文件的一些元数据,并将它们存储在数据库中。
我目前正在考虑为每个文件使用一个 grain,这样我可能会有数百万个 grain,但我想知道在这种情况下将每个 grain 同时保存到数据库是否会使数据库过载。
我想知道是否应该考虑以下情况之一来尽量减少数据库的并发负载:
我是否需要为这些烦恼,或者我是否可以简单地依靠 Orleans 运行时(可能通过设置)不要一次激活太多会尝试同时将数据保存到数据库的 Cereal ?
最佳答案
我会放弃第二个建议,因为由于难以写出结果,您会限制整个系统的吞吐量。这是对抗 Orleans 的最大优势之一,即几乎无限的可扩展性以响应需求。
您可以尝试修改第一个解决方案。我不会将结果返回给另一个 grain,而是让每个 grain 使用其文件读取的结果调用无状态服务,然后将持久性委托(delegate)给该服务。这可能是您的想法,但无状态服务不同于 Cereal ,所以我想说清楚。
如果系统出现故障,而此服务有一个正在尝试写入的行列表,这将打开丢失数据的大门。如果这是一个问题,我会让 grains 写入一个服务,该服务立即写入一个持久消息队列(即 RabbitMQ),然后另一个服务从该队列读取并写入数据库。我不会让 grains 直接写入消息队列,因为集中队列写入可以让您向该服务添加重试逻辑、断路器等。尝试为 1MM 颗粒添加共享断路器将是一场噩梦。
虽然你没有问,但我要提出另一个想法。我不禁质疑将所有这些数据放入数据库的决定。数据库非常擅长跟踪数据的变化,但我怀疑您正在收集的元数据将在以后进行分析,但不会被修改。这使得它成为事件流(例如 Azure 事件网格)的理想候选者。事件流针对写入进行了优化,可以轻松处理您正在谈论的浪涌类型。
关于c# - Microsoft Orleans 中的节流 Cereal ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59487095/
如何检查某个特定 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) 我正在寻找有关托管和部署的建议,基本上是:在哪里以及如何?
我是一名优秀的程序员,十分优秀!