我目前正在使用Booksleeve开发一个由Redis支持的ASP.NET SessionState自定义提供程序.Redis似乎非常适合SessionState(如果必须使用它),因为:
Redis可以像RDBMS一样持久存储,但速度要快得多.
键/值数据存储区更适合SessionState的接口.
由于数据不是存储在进程中(如默认的Session提供程序),因此SessionState可以实现Web服务器重启,崩溃等.
如果需要,Redis很容易水平分片.
所以,我想知道这对任何人都有用,因为我们(我的公司)正在考虑在GitHub上开源.思考?
我确实发布了昨天的第一个版本:https://github.com/angieslist/AL-Redis/blob/master/AngiesList.Redis/RedisSessionStateStore.cs
我创建了一个Redis的基础SessionStateStoreProvider
是可以在GitHub上找到使用ServiceStatck.Redis
的客户端(而非Booksleeve).
它可以通过NuGet安装Install-Package Harbour.RedisSessionStateStore
.
我发现@ NathanD的方法有些怪癖.在我的实现,锁是存储与会话值,而不是在单独的密钥(更少的往返Redis的).另外,因为它使用ServiceStack.Redis
,它可以使用池连接.
最后,它经过了测试.这是我对@ NathanD方法的最大转变.没有办法在没有手动运行每个用例的情况下实际知道它是否有效.