25

我能够通过使用在 ServiceStack.redis 中做到这一点,

IRedisTypedClient<ObjectName> myObj = redisClient.As<ObjectName>();

但我在 StackExchange.Redis 中找不到任何示例。

我是否必须序列化为 JSON 然后存储它们?

提前谢谢。

4

3 回答 3

29

目前,SE.Redis 并没有尝试提供序列化 - 有太多不同的方法可以做到这一点。我更倾向于认为库应该做一件事,而不是 7。应该可以通过扩展方法或其他管道/包装代码添加任何混合序列化等关注点,选择您选择的任何序列化策略和任何库你选。

于 2014-08-27T21:56:35.067 回答
11

最简单的解决方案是使用 json/binary/other 序列化。更复杂但更原生 - 使用 redis “哈希”数据类型

在第一种情况下,我更喜欢protobuf库(它默认包含在 StackExchange.Redis.Extensions.Protobuf nuget 包中)。但如果需要,您可以使用 json/binary/xml 序列化。

关于它们都有一个很好的性能报告:http: //www.maxondev.com/serialization-performance-comparison-c-net-formats-frameworks-xmldatacontractserializer-xmlserializer-binaryformatter-json-newtonsoft-servicestack-text/

于 2015-09-29T10:56:25.180 回答
4

示例:在下面创建辅助函数示例,在 get/set 之前使用 JSON SerializeObject/DeSerializeObject。但是这个解决方案的限制对象大小不能超过 Int32.MaxNumber ( 2,147,483,647 是 2Gb )。

示例代码

    public static void SetData<T>(string key, T data)
    {
        using (var redis = ConnectionMultiplexer.Connect("localhost:6379"))
        {
            IDatabase db = redis.GetDatabase();
            JavaScriptSerializer json_serializer = new JavaScriptSerializer();
            json_serializer.MaxJsonLength = int.MaxValue;

            db.StringSet(key, json_serializer.Serialize(data));
            redis.Close();
        }
    }

    public static T GetData<T>(string key)
    {
        using (var redis = ConnectionMultiplexer.Connect("localhost:6379"))
        {
            try
            {
                IDatabase db = redis.GetDatabase();
                var res = db.StringGet(key);

                redis.Close();
                if (res.IsNull)
                    return default(T);
                else
                    return JsonConvert.DeserializeObject<T>(res);
            }
            catch
            {
                return default(T);
            }

        }
    }
于 2018-07-02T11:28:48.903 回答