Redis 分布式session
这里有三种和方式实现:
1.Harbour.RedisSessionStateStore , ServiceStack.Redis
配置web.config
- <sessionState mode="Custom" customProvider="RedisSessionStateProvider">
- <providers>
- <clear />
- <add name="RedisSessionStateProvider"
- type="Harbour.RedisSessionStateStore.RedisSessionStateStoreProvider"
- host="localhost:6379" clientType="pooled" />
- </providers>
- </sessionState>
2.StackExchange.Redis RedisSessionStateProvider
配置文件web.config
- <sessionState mode="Custom" customProvider="MySessionStateStore">
- <providers>
- <add name="MySessionStateStore"
- type="Microsoft.Web.Redis.RedisSessionStateProvider"
- host="127.0.0.1"
- port="6379"
- accessKey="" ssl="true" />
- </providers>
- </sessionState>
3.自定义SessionStateStateProvider
借鉴网上的例子,需要做修改:
- public class RedisSessionStateStore : SessionStateStoreProviderBase
- {
- /// <summary>
- /// 创建新的Session执行
- /// </summary>
- public override SessionStateStoreData CreateNewStoreData(HttpContext context, int timeout)
- {
- return CreateLegitStoreData(context, null, null, timeout);
- }
- internal static SessionStateStoreData CreateLegitStoreData(HttpContext context, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
- {
- if (sessionItems == null)
- sessionItems = new SessionStateItemCollection();
- if (staticObjects == null && context != null)
- staticObjects = SessionStateUtility.GetSessionStaticObjects(context);
- return new SessionStateStoreData(sessionItems, staticObjects, timeout);
- }
- public override void CreateUninitializedItem(HttpContext context, string id, int timeout)
- {
- RedisSessionState state = new RedisSessionState(null, null, timeout);
- RedisBase.Item_Set<string>(id, state.ToJson(), timeout);
- }
- private SessionStateStoreData DoGet(HttpContext context, string id, bool exclusive, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
- {
- locked = false;
- lockId = null;
- lockAge = TimeSpan.Zero;
- actionFlags = SessionStateActions.None;
- RedisSessionState state = RedisSessionState.FromJson(RedisBase.Item_Get<string>(id));
- if (state == null)
- {
- return null;
- }
- RedisBase.Item_SetExpire(id, state._timeout);
- return CreateLegitStoreData(context, state._sessionItems, state._staticObjects, state._timeout);
- }
- /// <summary>
- /// 取值的时候执行
- /// </summary>
- public override SessionStateStoreData GetItem(HttpContext context, string id, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
- {
- return this.DoGet(context, id, false, out locked, out lockAge, out lockId, out actionFlags);
- }
- public override SessionStateStoreData GetItemExclusive(HttpContext context, string id, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
- {
- return this.DoGet(context, id, true, out locked, out lockAge, out lockId, out actionFlags);
- }
- /// <summary>
- /// 新增 修改 移除键值时执行
- /// </summary>
- /// <param name="item">item.Items为当前所有的键值对</param>
- public override void SetAndReleaseItemExclusive(HttpContext context, string id, SessionStateStoreData item, object lockId, bool newItem)
- {
- ISessionStateItemCollection sessionItems = null;
- HttpStaticObjectsCollection staticObjects = null;
- if (item.Items.Count > )
- sessionItems = item.Items;
- if (!item.StaticObjects.NeverAccessed)
- staticObjects = item.StaticObjects;
- RedisSessionState state2 = new RedisSessionState(sessionItems, staticObjects, item.Timeout);
- RedisBase.Item_Set<string>(id, state2.ToJson(), item.Timeout);
- }
- #region "未实现方法"
- public override void Dispose()
- {
- }
- public override void EndRequest(HttpContext context)
- {
- }
- public override void InitializeRequest(HttpContext context)
- {
- }
- public override void ReleaseItemExclusive(HttpContext context, string id, object lockId)
- {
- }
- public override void RemoveItem(HttpContext context, string id, object lockId, SessionStateStoreData item)
- {
- RedisBase.Item_Remove(id);
- }
- public override void ResetItemTimeout(HttpContext context, string id)
- {
- }
- public override bool SetItemExpireCallback(SessionStateItemExpireCallback expireCallback)
- {
- return true;
- }
- #endregion
- }
- internal sealed class SessionStateItem
- {
- public Dictionary<string, object> Dict;
- public int Timeout;
- }
- internal sealed class RedisSessionState
- {
- internal ISessionStateItemCollection _sessionItems;
- internal HttpStaticObjectsCollection _staticObjects;
- internal int _timeout;
- internal RedisSessionState(ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
- {
- this.Copy(sessionItems, staticObjects, timeout);
- }
- internal void Copy(ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
- {
- this._sessionItems = sessionItems;
- this._staticObjects = staticObjects;
- this._timeout = timeout;
- }
- public string ToJson()
- {
- // 这里忽略_staticObjects这个成员。
- if (_sessionItems == null || _sessionItems.Count == )
- {
- return null;
- }
- Dictionary<string, object> dict = new Dictionary<string, object>(_sessionItems.Count);
- string key;
- NameObjectCollectionBase.KeysCollection keys = _sessionItems.Keys;
- for (int i = ; i < keys.Count; i++)
- {
- key = keys[i];
- dict.Add(key, _sessionItems[key]);
- }
- SessionStateItem item = new SessionStateItem { Dict = dict, Timeout = this._timeout };
- return JsonConvert.SerializeObject(item);
- }
- public static RedisSessionState FromJson(string json)
- {
- if (string.IsNullOrEmpty(json))
- {
- return null;
- }
- try
- {
- SessionStateItem item = JsonConvert.DeserializeObject<SessionStateItem>(json);
- SessionStateItemCollection collections = new SessionStateItemCollection();
- foreach (KeyValuePair<string, object> kvp in item.Dict)
- {
- collections[kvp.Key] = kvp.Value;
- }
- return new RedisSessionState(collections, null, item.Timeout);
- }
- catch
- {
- return null;
- }
- }
- }
- <sessionState mode="Custom" customProvider="RedisSessionStateProvider">
- <providers>
- <clear />
- <add name="RedisSessionStateProvider"
- type="Harbour.RedisSessionStateStore.RedisSessionStateStoreProvider"
- host="localhost:6379" clientType="pooled" />
- </providers>
- </sessionState>
之前建了一个mvc的项目测试,但是创建了Action 没有创建对应的视图,一直不能再redis中增加值,以为自己配置错了,但是还是我想的太简单了,当返回一个view才完成一次请求,这样才能知道session的改变,才能做出相应的改变。注意下。
Redis 分布式session的更多相关文章
- C# redis 分布式session存储
https://github.com/uliian/SessionExtentionStore 一个基于Redis的Session存储扩展方案,解决ASP.NET中Session的局限性和跨应用程序使 ...
- 分布式中Redis实现Session终结篇
上一篇使用Redis实现Session共享方式虽然可行,但是实际操作起来却很麻烦,现有代码已经是这个样子了,总不可能全部换掉吧!好吧,这是个很实际的问题,那么能不能实现无侵入式的分布式Session共 ...
- 基于Spring Boot/Spring Session/Redis的分布式Session共享解决方案
分布式Web网站一般都会碰到集群session共享问题,之前也做过一些Spring3的项目,当时解决这个问题做过两种方案,一是利用nginx,session交给nginx控制,但是这个需要额外工作较多 ...
- redis/分布式文件存储系统/数据库 存储session,解决负载均衡集群中session不一致问题
先来说下session和cookie的异同 session和cookie不仅仅是一个存放在服务器端,一个存放在客户端那么笼统 session虽然存放在服务器端,但是也需要和客户端相互匹配,试想一个浏览 ...
- 项目分布式部署那些事(1):ONS消息队列、基于Redis的Session共享,开源共享
因业务发展需要现在的系统不足以支撑现在的用户量,于是我们在一周之前着手项目的性能优化与分布式部署的相关动作. 概况 现在的系统是基于RabbitHub(一套开源的开发时框架)和Rabbit.WeiXi ...
- [Node.js] Node + Redis 实现分布式Session方案
原文地址: http://www.moye.me/?p=565 Session是什么? Session 是面向连接的状态信息,是对 Http 无状态协议的补充. Session 怎么工作? Sessi ...
- 分布式Session共享(一):tomcat+redis实现session共享
一.前言 本文主要测试redis实现session共享的实现方式,不讨论如何让nginx参与实现负载均衡等. 二.环境配置 本测试在Window下进行 name version port Tomcat ...
- 实现Asp.net Mvc分布式Session Redis群集
Redis群集实现Asp.net Mvc分布式Session Session的缺点 众所周知Asp.net Session默认存储在IIS中,IIS的重启会导致Session丢失. 如果你的网站使用了 ...
- 一篇文章让你深透理解cookie和session,附带分布式WEB系统redis共享session方案
cookie和session有什么区别?这是一个很基础的知识点,大家可能都知道一个大概:cookie是存在客户端的,session是存储在服务端,cookie和session用来验证识别用户的登录状态 ...
随机推荐
- css选择器(选择<div>内所有<p>元素)
情况1:<div><p></div> 情况2:<div><a><p></p></a></div&g ...
- Jenkins邮件配置,实现邮件发送策略(可实现每个Job对应不同的发送邮箱)
前言: 首先,要有一个用来发送的邮箱,首选网易!参考:http://www.cnblogs.com/EasonJim/p/6051636.html,这里我注册了网易的免费企业邮箱. 并且我新建没多个邮 ...
- 利用PHPMailer发送邮件时报错
利用thinkphp集成PHPMailer发送邮件时报错:Failed to connect to server: Unable to find the socket transport “ssl” ...
- 利用iconv进行文件编码批量原地转换
将当前目录及其所有子目录中的以 java 为后缀的文件,从 GB18030 转换为 UTF-8: find . -name "*.java" -exec sh -c " ...
- struts2 Advanced Learning
catalog . 引言 . struts2的类型转换 . struts2的输入校验 . struts2的拦截器机制 . 使用struts2的Ajax支持 . struts2 OGNL表达式 . st ...
- easyui使用datagrid时列名包含特殊字符导致表头与数据错位的问题
做一个用easyui的datagrid显示数据的功能时发现表格的列头与数据错位了,而且这个现象不总是能重现,一直没搞清楚原因.后来偶然在控制台看出了一点端倪: 推测表头或者单元格的class名应该是用 ...
- Scala类基础
最近在开始学习Scala,本篇文章我们来讲解一下Scala中类的使用 class Counter { var defaultValue = 0 val valValue = 0 private var ...
- 如何判断ios设备中是否安装了某款应用
URL Schemes关键字研究一下即可 常见得URL Schemes见http://www.cnblogs.com/huangzs/p/4491286.html if ([[UIApplicatio ...
- JZOJ P1817:[8.27]研究性学习作业
传送门 老师良心推荐的二分题.7月29号第一次写,想到了裸的DP,乱搞搞过了6组,欲优化,无解,弃疗. 然后今天老师给了题解,简单看了一下. 正解是二分答案+DP验证. 二分天数$day$,然后对于每 ...
- Mysql配置项的简单优化
preface 众所周知,Mysql已经成为广泛使用的开源数据库了,so 公司阿里云的数据库为Mysql,在最开始的时候是直接yum安装,配置项都是默认的,没有任何调整,这次有时间就参考各路大神的资料 ...