我在集群架构中使用akka.net。 (n)处理节点,目前有1个灯塔。
浏览网络的一个软件包公开了语言信息。
/// <summary>
/// Define scored a suite of token info
/// </summary>
/// <seealso cref="Hammer.Immutable.ImmutableObject" />
[DataContract]
public sealed class TokenSuite : ImmutableObject, IIdItem
{
#region Ctor
/// <summary>
/// Initializes a new instance of the <see cref="TokenSuite"/> class.
/// </summary>
public TokenSuite(Guid id, string langCode)
: base(id, langCode)
{
this.Id = id;
this.LangCode = langCode;
if (!string.IsNullOrEmpty(langCode))
LangInfo = CultureInfo.GetCultureInfoByIetfLanguageTag(langCode);
}
#endregion
#region Properties
/// <summary>
/// Gets the identifier.
/// </summary>
[DataMember]
public Guid Id { get; }
/// <summary>
/// Gets the main language code.
/// </summary>
[DataMember]
public string LangCode { get; }
/// <summary>
/// Gets the lang information.
/// </summary>
[IgnoreDataMember]
public CultureInfo LangInfo { get; }
#endregion
在本地没问题,但当它通过网络(序列化)时,我在灯塔上遇到了这个问题:
读取它似乎来自CultureInfo对象的错误,但它是在序列化中被忽略的标志。
我使用Akka版本1.3.5,Hyperion 0.9.8,Akka.Serialization.Hyperion 1.3.2-beta54。
我尝试在本地序列化它的工作原理:
var serializer = Context.System.Serialization.FindSerializerForType(typeof(TokenSuite));
var data = serializer.ToBinary(result);
var rtoObjectBack = serializer.FromBinary<TokenSuite>(data);
任何的想法 ?
Hyperion不会使用数据协定属性。这也意味着不会考虑[IgnoreDataMember]
。
可能它在尝试反序列化CultureInfo
对象时失败了,你提供了。您始终可以尝试将其转换为字符串,并在反序列化后解析。