- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我使用 RedisConnection Set 方法设置字节数组,但如何获取数据? get 返回一个包装的字节数组?
链接:
这行得通,但感觉不对:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using BookSleeve;
using ProtoBuf;
using System.IO;
namespace RedisTest001
{
[ProtoContract, Serializable]
public class Price
{
private string _ticker;
private double _value;
public Price()
{
}
public Price(string ticker, double value)
{
_ticker = ticker;
_value = value;
}
[ProtoMember(1)]
public string Ticker
{
get { return _ticker; }
set { _ticker = value; }
}
[ProtoMember(2)]
public double Value
{
get { return _value; }
set { _value = value; }
}
}
class Program
{
static void Main(string[] args)
{
using (var conn = new RedisConnection("localhost"))
{
Price p = new Price("IBM", 101.55);
byte[] raw;
using (MemoryStream ms = new MemoryStream())
{
Serializer.Serialize<Price>(ms,p);
raw = ms.ToArray();
}
conn.Open();
conn.Set(1, p.Ticker, raw);
var tb = conn.Get(1,"IBM");
var str = conn.Wait(tb);
Price p2 = Serializer.Deserialize<Price>(new MemoryStream(str));
}
}
}
}
更多信息:
public static class pex
{
public static byte[] ToBArray<T>(this T o)
{
using (MemoryStream ms = new MemoryStream())
{
Serializer.Serialize<T>(ms, o);
return ms.ToArray();
}
}
}
class Program
{
static void Main(string[] args)
{
Random RandomClass = new Random();
using (var conn = new RedisConnection("localhost"))
{
conn.Open();
for (int i = 0; i < 500000; i++)
{
Price p = new Price("IBM", RandomClass.Next(0, 1000));
conn.AddToSet(2, "PRICE.IBM", p.ToBArray());
}
最佳答案
完全正确。 “获取”(BookSleeve) 返回延迟的 byte[]
。您已正确使用 Wait 来获取实际的 byte[]
,然后在此 byte[]
上使用 MemoryStream
来调用 Deserialize
通过 protobuf-net。
一切顺利。
如果你把你觉得丑陋的任何步骤说清楚,我可能会更具体,但是:
Task
完全异步,因此需要 Wait
或 ContinueWith
来访问 byte[]
MemoryStream
位于 byte[]
当然,如果你添加一个通用的实用方法(也许是一个扩展方法)你只需要写一次。
加上一个包装器类(用于某些跟踪/滑动过期)和一个 L1 缓存(Redis 作为 L2),这与我们在 stackoverflow 中使用它的方式非常精确。
请注意:该连接是线程安全的,旨在大规模共享;不要对每个操作都进行连接。
关于redis - 我应该如何将 Booksleeve 与 protobuf-net 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6477623/
我是 Redis 和 BookSleeve 的新手。我正在评估是否应该使用 BookSleeve 或 ServiceStack.Redis。 ServiceStack 看起来更直接,但我喜欢 Book
我需要在现有集合和用户输入的一些值之间执行 Except 操作。我怎样才能最好地做到这一点?我首先考虑使用一个临时集来存储用户的值。这会在多线程应用程序(网络)中工作吗?如果是这样,我如何确定在执行
我正在更新我的网络服务以使用最新的 BookSleeve图书馆,1.3.38。以前我用的是 1.1.0.7 在做一些基准测试时,我注意到使用新版本的 BookSleeve 在 Redis 中设置哈希比
我无法通过执行以下操作重新连接到我的 Redis 数据库: 创建一个名为“connection”的新 RedisConnection 打开连接connection.Open().Wait(); 关闭连
当我使用 BookSleeve 连接到我的 Redis 服务器并从中添加/获取条目时,我收到了一个 SocketException。具体的异常(exception)是:通常只允许每个套接字地址(协议(
所以我有这个单元测试: [TestMethod] public void TestNullString() { String expectedTestValue = null; var
我正在尝试根据 BookSleeve 组合一个 super 简单的排队示例。 到目前为止,这是我在队列消费者方面所拥有的: using System; using System.Text; using
是否有关于 BookSleeve Redis 入门的文章或资源?谢谢 最佳答案 这些是我在加快速度时阅读的一些文章/链接: http://marcgravell.blogspot.com/2011/0
我正在尝试使用 Redis Booksleeve 存储多个成员(member)评分值,但 Booksleeve api 似乎不支持此功能。 conn.SortedSets.Add 重载仅支持单对值 -
除非我遗漏了什么,否则我看不到允许您设置多个具有到期时间的 key 的 Multiple Set/Add 重载。 var conn = new RedisConnection("server"); D
我有大约 336 个键要删除,它们是 SortedSet,我在 Ubuntu 服务器上使用 BookSleeve 作为 C3 客户端和 Redis。下面的代码有效,但如果我删除 Console.Wri
BookSleeve性能非常好,因为它尽可能多地使用异步 IO。 但问题是,它可能会从异步操作中抛出致命异常并使我的应用程序崩溃。 我知道关键字 await 可以提供帮助,但我不能在每次调用时都使用
谁能告诉我如何从 BookSleeve 调用命令 BGSAVE 到 Redis? 我在 BookSleeve 中搜索了很多可用的方法,但没有找到任何与 SAVE 或 BGSAVE 相关的命令。 谢谢!
我正在使用 Booksleeve 通过 C# 代码与 Redis 通信。该代码首先从哈希中检索所有字段和值: var vals = await Redis.Hashes.GetAll(0, redis
我正在尝试获取值列表,其中键名称以“猴子”开头。 我真的找不到这方面的文档。 :( 我该怎么做?我应该使用什么 API? 键、集合、字符串?什么方法? 或者它尚不可用,但有解决方法? 谢谢 最佳答案
我正在为 Redis 使用 Booksleeve 哈希 API。我正在做以下事情: CurrentConnection.Hashes.Set(0, "item:1", "priority", ta
我一直在 C# 中使用 Booksleeve 作为我的 redis 驱动程序并且对此非常满意 - 但我发现需要对排序集进行一些工作。看起来这些在 Booksleeve 中只得到最少的支持——例如,没有
我正在尝试在 appharbor 上设置 Redis。我已按照他们的说明进行操作,但我再次遇到 Booksleeve API 问题。这是我用来使其最初工作的代码: var
我有以下类(class)女巫在论坛中存储一条消息 using System; using System.Collections.Generic; public partial class ForumM
我对 Marc Gravell 的 Booksleeve 图书馆有疑问。 我试图了解 booksleeve 如何处理 Int64 值(实际上我在 Redis 中有 billion long 值) 我使
我是一名优秀的程序员,十分优秀!