- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Orleans 7.0 项目,但我在使用新的默认序列化器时遇到了问题。
Orleans 3.6.5 中的旧序列化程序运行良好,它可以序列化几个内部 Nuget 包中的所有模型和 Dtos。
现在在 Orleans 7.0 中,该项目无法识别 Nuget 包中的模型,并且我收到此错误:
Orleans.Serialization.CodecNotFoundException: Could not find a copier for type InternalProject.Model.
at Orleans.Serialization.Serializers.CodecProvider.ThrowCopierNotFound(Type type) in /_/src/Orleans.Serialization/Serializers/CodecProvider.cs:line 666
at Orleans.Serialization.Serializers.CodecProvider.GetDeepCopier[T]() in /_/src/Orleans.Serialization/Serializers/CodecProvider.cs:line 300
at Orleans.Serialization.ServiceCollectionExtensions.CopierHolder`1.get_Value() in /_/src/Orleans.Serialization/Hosting/ServiceCollectionExtensions.cs:line 203
at Orleans.Serialization.GeneratedCodeHelpers.OrleansGeneratedCodeHelper.GetService[TService](Object caller, ICodecProvider codecProvider) in /_/src/Orleans.Serialization/GeneratedCodeHelpers/OrleansGeneratedCodeHelper.cs:lin
e 75
at OrleansCodeGen.InternalProject.Model.Copier_SpecificModel..ctor(ICodecProvider codecProvider) in C:\Projects\InternalProject.Model\Orleans.CodeGenerator\Orleans.CodeGenerator.Orle
ansSerializationSourceGenerator\InternalProject.Model.orleans.g.cs:line 20736
at System.RuntimeMethodHandle.InvokeMethod(Object target, Void** arguments, Signature sig, Boolean isConstructor)
at System.Reflection.ConstructorInvoker.Invoke(Object obj, IntPtr* args, BindingFlags invokeAttr)
at System.Reflection.RuntimeConstructorInfo.Invoke(BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
at Microsoft.Extensions.DependencyInjection.ActivatorUtilities.ConstructorMatcher.CreateInstance(IServiceProvider provider)
at Microsoft.Extensions.DependencyInjection.ActivatorUtilities.CreateInstance(IServiceProvider provider, Type instanceType, Object[] parameters)
at Microsoft.Extensions.DependencyInjection.ActivatorUtilities.GetServiceOrCreateInstance[T](IServiceProvider provider)
at Orleans.Serialization.GeneratedCodeHelpers.OrleansGeneratedCodeHelper.GetService[TService](Object caller, ICodecProvider codecProvider) in /_/src/Orleans.Serialization/GeneratedCodeHelpers/OrleansGeneratedCodeHelper.cs:lin
e 72
现在有趣的部分是:当我在主项目中复制粘贴完全相同的类时,我不再收到此错误,并且该类序列化得很好。
我尝试在主项目中直接引用Nuget项目(ProjectReference),结果是一样的。
我只在两种情况下消除错误:
siloBuilder.Services.AddSerializer(sb =>
{
sb.AddJsonSerializer(
isSupported: type => type.Namespace.StartsWith("Nuget.Namespace"),
new JsonSerializerOptions()
{
ReferenceHandler = ReferenceHandler.IgnoreCycles
}
);
});
[GenerateSerializer]
public sealed class Class1: Class1Base
{
public Class1()
{
}
public Class1(IRequest request, bool boolean, InternalClass internalClass)
: base(request, boolean)
{
InternalClass = internalClass;
}
[Id(0)]
public InternalClass InternalClass{ get; set; }
}
[GenerateSerializer]
public class Class1Base
{
public Class1Base()
{
}
public Class1Base(IRequest request, bool boolean)
{
Request = request;
Boolean= boolean;
}
[Id(0)]
public IRequest Request { get; set; }
[Id(1)]
public bool Boolean{ get; set; }
}
最佳答案
奥尔良序列化器具有很多性能和灵活性优势,但正如您所发现的,它在使用第三方类型方面具有非常硬的优势。您有几个选择,但都不是很好
继续使用第 3 方类型并为要序列化的每种类型定义代理和编解码器。这可能是一项非常繁重的工作,而且可能不是最好的主意。 See this document for how to do that ,但请注意,如果您不小心错过了图中的某个类型,它会在运行时崩溃,因此请确保您的测试良好。
使用不同的序列化器。 Orleans 附带了基于 Json 的序列化器,更容易使用。它们可能不如 Orleans Serializer 快,但运行起来要简单得多。这是最简单的选择,而且几乎没有什么缺点。 See this article on how to do that
从 DTO 中删除第 3 方类型。在此选项中,您可以更改grain合约,以便仅使用第一方类型(您自己定义的类型)在grains之间发送消息。这不太方便,并且消除了奥尔良对象透明度的一些魔力,但消除了问题。这是我在我的案例中选择的选项,因为我认为它可以使我的模型更清晰。
我还怀疑,通过大量的努力,可以编写一个源生成器,它可以自动遍历grain调用中使用的对象图,并自动生成第三方类型的编解码器和代理,以完全消除这个问题。但我觉得没有必要。
关于c# - Orleans 7.0 序列化程序无法与源自 Nuget 包的 POCO 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75397083/
如何检查某个特定 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) 我正在寻找有关托管和部署的建议,基本上是:在哪里以及如何?
我是一名优秀的程序员,十分优秀!