这里有三种和方式实现:

1.Harbour.RedisSessionStateStore , ServiceStack.Redis

配置web.config

  1. <sessionState mode="Custom" customProvider="RedisSessionStateProvider">
  2. <providers>
  3. <clear />
  4. <add name="RedisSessionStateProvider"
  5. type="Harbour.RedisSessionStateStore.RedisSessionStateStoreProvider"
  6. host="localhost:6379" clientType="pooled" />
  7. </providers>
  8. </sessionState>

2.StackExchange.Redis RedisSessionStateProvider

配置文件web.config

  1. <sessionState mode="Custom" customProvider="MySessionStateStore">
  2. <providers>
  3. <add name="MySessionStateStore"
  4. type="Microsoft.Web.Redis.RedisSessionStateProvider"
  5. host="127.0.0.1"
  6. port="6379"
  7. accessKey="" ssl="true" />
  8. </providers>
  9. </sessionState>

3.自定义SessionStateStateProvider

借鉴网上的例子,需要做修改:

  1. public class RedisSessionStateStore : SessionStateStoreProviderBase
  2. {
  3. /// <summary>
  4. /// 创建新的Session执行
  5. /// </summary>
  6. public override SessionStateStoreData CreateNewStoreData(HttpContext context, int timeout)
  7. {
  8. return CreateLegitStoreData(context, null, null, timeout);
  9. }
  10.  
  11. internal static SessionStateStoreData CreateLegitStoreData(HttpContext context, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
  12. {
  13. if (sessionItems == null)
  14. sessionItems = new SessionStateItemCollection();
  15. if (staticObjects == null && context != null)
  16. staticObjects = SessionStateUtility.GetSessionStaticObjects(context);
  17. return new SessionStateStoreData(sessionItems, staticObjects, timeout);
  18. }
  19.  
  20. public override void CreateUninitializedItem(HttpContext context, string id, int timeout)
  21. {
  22. RedisSessionState state = new RedisSessionState(null, null, timeout);
  23. RedisBase.Item_Set<string>(id, state.ToJson(), timeout);
  24. }
  25.  
  26. private SessionStateStoreData DoGet(HttpContext context, string id, bool exclusive, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
  27. {
  28. locked = false;
  29. lockId = null;
  30. lockAge = TimeSpan.Zero;
  31. actionFlags = SessionStateActions.None;
  32. RedisSessionState state = RedisSessionState.FromJson(RedisBase.Item_Get<string>(id));
  33. if (state == null)
  34. {
  35. return null;
  36. }
  37. RedisBase.Item_SetExpire(id, state._timeout);
  38. return CreateLegitStoreData(context, state._sessionItems, state._staticObjects, state._timeout);
  39. }
  40.  
  41. /// <summary>
  42. /// 取值的时候执行
  43. /// </summary>
  44. public override SessionStateStoreData GetItem(HttpContext context, string id, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
  45. {
  46. return this.DoGet(context, id, false, out locked, out lockAge, out lockId, out actionFlags);
  47. }
  48.  
  49. public override SessionStateStoreData GetItemExclusive(HttpContext context, string id, out bool locked, out TimeSpan lockAge, out object lockId, out SessionStateActions actionFlags)
  50. {
  51. return this.DoGet(context, id, true, out locked, out lockAge, out lockId, out actionFlags);
  52. }
  53.  
  54. /// <summary>
  55. /// 新增 修改 移除键值时执行
  56. /// </summary>
  57. /// <param name="item">item.Items为当前所有的键值对</param>
  58. public override void SetAndReleaseItemExclusive(HttpContext context, string id, SessionStateStoreData item, object lockId, bool newItem)
  59. {
  60. ISessionStateItemCollection sessionItems = null;
  61. HttpStaticObjectsCollection staticObjects = null;
  62.  
  63. if (item.Items.Count > )
  64. sessionItems = item.Items;
  65. if (!item.StaticObjects.NeverAccessed)
  66. staticObjects = item.StaticObjects;
  67.  
  68. RedisSessionState state2 = new RedisSessionState(sessionItems, staticObjects, item.Timeout);
  69.  
  70. RedisBase.Item_Set<string>(id, state2.ToJson(), item.Timeout);
  71. }
  72.  
  73. #region "未实现方法"
  74.  
  75. public override void Dispose()
  76. {
  77.  
  78. }
  79.  
  80. public override void EndRequest(HttpContext context)
  81. {
  82.  
  83. }
  84.  
  85. public override void InitializeRequest(HttpContext context)
  86. {
  87.  
  88. }
  89.  
  90. public override void ReleaseItemExclusive(HttpContext context, string id, object lockId)
  91. {
  92. }
  93.  
  94. public override void RemoveItem(HttpContext context, string id, object lockId, SessionStateStoreData item)
  95. {
  96. RedisBase.Item_Remove(id);
  97. }
  98.  
  99. public override void ResetItemTimeout(HttpContext context, string id)
  100. {
  101.  
  102. }
  103.  
  104. public override bool SetItemExpireCallback(SessionStateItemExpireCallback expireCallback)
  105. {
  106. return true;
  107. }
  108.  
  109. #endregion
  110.  
  111. }
  112. internal sealed class SessionStateItem
  113. {
  114. public Dictionary<string, object> Dict;
  115. public int Timeout;
  116. }
  117.  
  118. internal sealed class RedisSessionState
  119. {
  120. internal ISessionStateItemCollection _sessionItems;
  121. internal HttpStaticObjectsCollection _staticObjects;
  122. internal int _timeout;
  123.  
  124. internal RedisSessionState(ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
  125. {
  126. this.Copy(sessionItems, staticObjects, timeout);
  127. }
  128.  
  129. internal void Copy(ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout)
  130. {
  131. this._sessionItems = sessionItems;
  132. this._staticObjects = staticObjects;
  133. this._timeout = timeout;
  134. }
  135.  
  136. public string ToJson()
  137. {
  138. // 这里忽略_staticObjects这个成员。
  139.  
  140. if (_sessionItems == null || _sessionItems.Count == )
  141. {
  142. return null;
  143. }
  144.  
  145. Dictionary<string, object> dict = new Dictionary<string, object>(_sessionItems.Count);
  146.  
  147. string key;
  148. NameObjectCollectionBase.KeysCollection keys = _sessionItems.Keys;
  149. for (int i = ; i < keys.Count; i++)
  150. {
  151. key = keys[i];
  152. dict.Add(key, _sessionItems[key]);
  153. }
  154.  
  155. SessionStateItem item = new SessionStateItem { Dict = dict, Timeout = this._timeout };
  156.  
  157. return JsonConvert.SerializeObject(item);
  158. }
  159.  
  160. public static RedisSessionState FromJson(string json)
  161. {
  162. if (string.IsNullOrEmpty(json))
  163. {
  164. return null;
  165. }
  166. try
  167. {
  168. SessionStateItem item = JsonConvert.DeserializeObject<SessionStateItem>(json);
  169.  
  170. SessionStateItemCollection collections = new SessionStateItemCollection();
  171.  
  172. foreach (KeyValuePair<string, object> kvp in item.Dict)
  173. {
  174. collections[kvp.Key] = kvp.Value;
  175. }
  176.  
  177. return new RedisSessionState(collections, null, item.Timeout);
  178. }
  179. catch
  180. {
  181. return null;
  182. }
  183. }
  184. }
  1. <sessionState mode="Custom" customProvider="RedisSessionStateProvider">
  2. <providers>
  3. <clear />
  4. <add name="RedisSessionStateProvider"
  5. type="Harbour.RedisSessionStateStore.RedisSessionStateStoreProvider"
  6. host="localhost:6379" clientType="pooled" />
  7. </providers>
  8. </sessionState>

之前建了一个mvc的项目测试,但是创建了Action 没有创建对应的视图,一直不能再redis中增加值,以为自己配置错了,但是还是我想的太简单了,当返回一个view才完成一次请求,这样才能知道session的改变,才能做出相应的改变。注意下。

Redis 分布式session的更多相关文章

  1. C# redis 分布式session存储

    https://github.com/uliian/SessionExtentionStore 一个基于Redis的Session存储扩展方案,解决ASP.NET中Session的局限性和跨应用程序使 ...

  2. 分布式中Redis实现Session终结篇

    上一篇使用Redis实现Session共享方式虽然可行,但是实际操作起来却很麻烦,现有代码已经是这个样子了,总不可能全部换掉吧!好吧,这是个很实际的问题,那么能不能实现无侵入式的分布式Session共 ...

  3. 基于Spring Boot/Spring Session/Redis的分布式Session共享解决方案

    分布式Web网站一般都会碰到集群session共享问题,之前也做过一些Spring3的项目,当时解决这个问题做过两种方案,一是利用nginx,session交给nginx控制,但是这个需要额外工作较多 ...

  4. redis/分布式文件存储系统/数据库 存储session,解决负载均衡集群中session不一致问题

    先来说下session和cookie的异同 session和cookie不仅仅是一个存放在服务器端,一个存放在客户端那么笼统 session虽然存放在服务器端,但是也需要和客户端相互匹配,试想一个浏览 ...

  5. 项目分布式部署那些事(1):ONS消息队列、基于Redis的Session共享,开源共享

    因业务发展需要现在的系统不足以支撑现在的用户量,于是我们在一周之前着手项目的性能优化与分布式部署的相关动作. 概况 现在的系统是基于RabbitHub(一套开源的开发时框架)和Rabbit.WeiXi ...

  6. [Node.js] Node + Redis 实现分布式Session方案

    原文地址: http://www.moye.me/?p=565 Session是什么? Session 是面向连接的状态信息,是对 Http 无状态协议的补充. Session 怎么工作? Sessi ...

  7. 分布式Session共享(一):tomcat+redis实现session共享

    一.前言 本文主要测试redis实现session共享的实现方式,不讨论如何让nginx参与实现负载均衡等. 二.环境配置 本测试在Window下进行 name version port Tomcat ...

  8. 实现Asp.net Mvc分布式Session Redis群集

    Redis群集实现Asp.net Mvc分布式Session Session的缺点 众所周知Asp.net Session默认存储在IIS中,IIS的重启会导致Session丢失. 如果你的网站使用了 ...

  9. 一篇文章让你深透理解cookie和session,附带分布式WEB系统redis共享session方案

    cookie和session有什么区别?这是一个很基础的知识点,大家可能都知道一个大概:cookie是存在客户端的,session是存储在服务端,cookie和session用来验证识别用户的登录状态 ...

随机推荐

  1. css选择器(选择<div>内所有<p>元素)

    情况1:<div><p></div> 情况2:<div><a><p></p></a></div&g ...

  2. Jenkins邮件配置,实现邮件发送策略(可实现每个Job对应不同的发送邮箱)

    前言: 首先,要有一个用来发送的邮箱,首选网易!参考:http://www.cnblogs.com/EasonJim/p/6051636.html,这里我注册了网易的免费企业邮箱. 并且我新建没多个邮 ...

  3. 利用PHPMailer发送邮件时报错

    利用thinkphp集成PHPMailer发送邮件时报错:Failed to connect to server: Unable to find the socket transport “ssl” ...

  4. 利用iconv进行文件编码批量原地转换

    将当前目录及其所有子目录中的以 java 为后缀的文件,从 GB18030 转换为 UTF-8: find .  -name "*.java" -exec sh -c " ...

  5. struts2 Advanced Learning

    catalog . 引言 . struts2的类型转换 . struts2的输入校验 . struts2的拦截器机制 . 使用struts2的Ajax支持 . struts2 OGNL表达式 . st ...

  6. easyui使用datagrid时列名包含特殊字符导致表头与数据错位的问题

    做一个用easyui的datagrid显示数据的功能时发现表格的列头与数据错位了,而且这个现象不总是能重现,一直没搞清楚原因.后来偶然在控制台看出了一点端倪: 推测表头或者单元格的class名应该是用 ...

  7. Scala类基础

    最近在开始学习Scala,本篇文章我们来讲解一下Scala中类的使用 class Counter { var defaultValue = 0 val valValue = 0 private var ...

  8. 如何判断ios设备中是否安装了某款应用

    URL Schemes关键字研究一下即可 常见得URL Schemes见http://www.cnblogs.com/huangzs/p/4491286.html if ([[UIApplicatio ...

  9. JZOJ P1817:[8.27]研究性学习作业

    传送门 老师良心推荐的二分题.7月29号第一次写,想到了裸的DP,乱搞搞过了6组,欲优化,无解,弃疗. 然后今天老师给了题解,简单看了一下. 正解是二分答案+DP验证. 二分天数$day$,然后对于每 ...

  10. Mysql配置项的简单优化

    preface 众所周知,Mysql已经成为广泛使用的开源数据库了,so 公司阿里云的数据库为Mysql,在最开始的时候是直接yum安装,配置项都是默认的,没有任何调整,这次有时间就参考各路大神的资料 ...