4

我将 json 数据列表存储在 redis 中,并使用 ServiceStack c# 客户端访问它。我本质上是在管理我自己的外键,我在其中存储一个zrangeid,并使用我的应用程序内部的一个接口zrange从我的申请。

正如我预期的那样,我正在使用PooledRedisClientManagerRedis 托管在与执行代码的服务器不同的服务器上。

我正在使用 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);

任何帮助将不胜感激。

4

2 回答 2

8

目前我最大的挑战是客户端连接没有被关闭。

您正在使用“PooledRedisClientManager”,所以我的理解是不应关闭客户端连接,只需将其放入池中以供重用。看起来您的池大小是 100 个连接。

您可以尝试使用 var mgr = new BasicRedisClientManager("localhost:6379") which should dispose 客户端。

于 2013-02-13T19:04:03.210 回答
2

编辑不建议使用以下方法 - 您应该依赖 IRedisClientsManager 并将所有 redis 客户端调用包装在 using() 块中,否则您被 gremlins 咬住。

我在让 Windsor 与 PooledRedisClientsManager 很好地配合时遇到了类似的问题,最后这似乎奏效了:

        container.Register(
            Component.For<IRedisClientsManager>()
                     .Instance(redisClients)
                     .LifestyleSingleton(),

            Component.For<IRedisClient>()
                     .UsingFactoryMethod(c => c.Resolve<IRedisClientsManager>().GetClient(),
                                        managedExternally: true));
    }

managedExternally 参数告诉 Windsor 不要尝试将停用问题应用于 IRedisClients,并让 PooledRedisClientsManager 处理回收。

于 2013-02-20T13:43:33.540 回答