我将 json 数据列表存储在 redis 中,并使用 ServiceStack c# 客户端访问它。我本质上是在管理我自己的外键,我在其中存储一个zrange
id,并使用我的应用程序内部的一个接口zrange
从我的申请。
正如我预期的那样,我正在使用PooledRedisClientManager
Redis 托管在与执行代码的服务器不同的服务器上。
我正在使用 MSOpenTech Redis 服务器在 Windows 8 上本地完成我的所有开发工作。目前我最大的挑战是客户端连接没有被关闭。
我的 Redis 持久化器被注入了一个IRedisClientManager
(IoC 是 CastleWindsor)的实例。此代码在 azure worker 角色的上下文中执行。
这就是我从 zrange 中获取项目的方式:
public class MyRedisPersister<T> : IResourcePersister<T>
{
IRedisClientManager _mgr;
public MyRedisPersister(IRedisClientManager mgr)
{
_mgr = mgr;
}
public IResourceList<T> Get<T>(string key, int offset, int count) where T
{
using (var redis = _clientManager.GetClient())
{
var itemKeys = redis.GetRangeFromSortedSet(key, offset, offset + count - 1).ToList();
var totalItems = redis.GetSortedSetCount(key);
if (itemKeys.Count == 0)
{
return new ResourceList<T>
{
Items = new List<T>(),
Offset = 0,
PageSize = 0,
TotalItems = 0,
TotalPages = 0
};
}
else
{
return new ResourceList<T>
{
Items = itemKeys.Select(k => redis.Get<T>(k)).ToList(),
Offset = offset,
PageSize = count,
TotalItems = totalItems,
TotalPages = (int) Math.Ceiling((float) totalItems/count)
};
}
}
}
}
这是我用来注册的代码IRedisClientManager
var mgr = new PooledRedisClientManager(100, 10, "localhost:6379");
container.Register(Component.For<IRedisClientsManager>().Instance(mgr).LifeStyle.Singleton);
任何帮助将不胜感激。