Akka.net Hyperion IgnoringDataMember

问题描述 投票:0回答:1

我在集群架构中使用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

在本地没问题,但当它通过网络(序列化)时,我在灯塔上遇到了这个问题:LightHouse Issue

读取它似乎来自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);

任何的想法 ?

serialization akka.net hyperion
1个回答
1
投票

Hyperion不会使用数据协定属性。这也意味着不会考虑[IgnoreDataMember]

可能它在尝试反序列化CultureInfo对象时失败了,你提供了。您始终可以尝试将其转换为字符串,并在反序列化后解析。

© www.soinside.com 2019 - 2024. All rights reserved.