1、这两天研究Redis搞分布式session问题,网上找的资料都是用ServiceStack.Redis来实现的,但是在做性能测试的时候发现最新的v4版本有限制每小时候最多请求6000次,因为官网开始商业化要收费了,好坑爹的说,还好我前期弄了个性能测试列子,不然上线以后出问题那就麻烦了。后面找了个NServiceKit.Redis(好像就是ServiceStack.Redis的v3版本)来替代v4的收费版。

2、解决方案是 Redis+cookie方式实现记录用户登录状态

cookie:存放用户的ID,这个ID是经过加密的,并且后台可以通过密钥解密。

Redis:key/value 方式存储,key存放比如:user_1。  value存放用户实体对象。

3、先安装一个Redis,windows的版本在本地进行测试,后期上线更换linux系统的Redis替换一下ip就可以了。

4、添加一个Session管理类

public class SessionHelper{private const int secondsTimeOut = 60 * 20;  //默认过期时间20分钟  单位秒public RedisHelper Redis = new RedisHelper(false);public LoginUserInfo this[string key]{get{string webCookie = WebHelper.GetCookie(key);if (webCookie == ""){return null;}key = key + "_" + SecureHelper.AESDecrypt(webCookie);//距离过期时间还有多少秒long l = Redis.TTL(key);if (l >= 0){Redis.Expire(key, secondsTimeOut);}return Redis.Get<LoginUserInfo>(key);}set{SetSession(key, value);}}public void SetSession(string key, LoginUserInfo value){if (string.IsNullOrWhiteSpace(key)){throw new Exception("Key is Null or Epmty");}WebHelper.SetCookie(key, SecureHelper.AESEncrypt(value.ID.ToString()));key = key + "_" + value.ID;Redis.Set<LoginUserInfo>(key, value, secondsTimeOut);}/// <summary>/// 移除Session/// </summary>/// <param name="key"></param>/// <returns></returns>public bool Remove(string key){var rs = Redis.Remove(key + "_" + SecureHelper.AESDecrypt(WebHelper.GetCookie(key)));WebHelper.DeleteCookie(key);return rs;}}

5、Redis操作类

public class RedisHelper : IDisposable{private RedisClient Redis = new RedisClient("127.0.0.1", 6379);//缓存池PooledRedisClientManager prcm = new PooledRedisClientManager();//默认缓存过期时间单位秒public int secondsTimeOut = 20 * 60;/// <summary>/// 缓冲池/// </summary>/// <param name="readWriteHosts"></param>/// <param name="readOnlyHosts"></param>/// <returns></returns>public static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts){return new PooledRedisClientManager(readWriteHosts, readOnlyHosts,new RedisClientManagerConfig{MaxWritePoolSize = readWriteHosts.Length * 5,MaxReadPoolSize = readOnlyHosts.Length * 5,AutoStart = true,}); }/// <summary>/// 构造函数/// </summary>/// <param name="OpenPooledRedis">是否开启缓冲池</param>public RedisHelper(bool OpenPooledRedis = false){if (OpenPooledRedis){prcm = CreateManager(new string[] { "127.0.0.1:6379" }, new string[] { "127.0.0.1:6379" });Redis = prcm.GetClient() as RedisClient;}}/// <summary>/// 距离过期时间还有多少秒/// </summary>/// <param name="key"></param>/// <returns></returns>public long TTL(string key){return Redis.Ttl(key);}/// <summary>/// 设置过期时间/// </summary>/// <param name="key"></param>/// <param name="timeout"></param>public void Expire(string key,int timeout = 0){if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(key, secondsTimeOut);}}#region Key/Value存储/// <summary>/// 设置缓存/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">缓存建</param>/// <param name="t">缓存值</param>/// <param name="timeout">过期时间,单位秒,-1:不过期,0:默认过期时间</param>/// <returns></returns>public bool Set<T>(string key, T t, int timeout = 0){Redis.Set<T>(key, t);if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(key, secondsTimeOut);}return true;}/// <summary>/// 获取/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key"></param>/// <returns></returns>public T Get<T>(string key){return Redis.Get<T>(key);}/// <summary>/// 删除/// </summary>/// <param name="key"></param>/// <returns></returns>public bool Remove(string key){return Redis.Remove(key);}#endregion//释放资源public void Dispose(){if (Redis != null){Redis.Dispose();Redis = null;}GC.Collect();}}

转载于:https://www.cnblogs.com/valen/p/4655427.html

asp.net mvc 用Redis实现分布式集群共享Session。相关推荐

  1. Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享

    转载自  Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享 一.Session共享使用tomcat-cluster-redis-session-mana ...

  2. 用Redis存储Tomcat集群的Session

    用Redis存储Tomcat集群的Session 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 前段时间,我花了不少时间来寻求一种方法,把新开发的代码推 ...

  3. Redis+Tomcat实现集群的Session管理

    Redis+Tomcat实现集群的Session管理 本地环境 JDK java version "1.8.0_102" Tomcat apache-tomcat-7.0.90 R ...

  4. redis全分布式集群

    文章目录 前言 Redis集群分片 槽位分片举例: Redis集群节点复制 Redis集群故障转移 全分布式集群搭建 Redis集群总结 前言 之前我们介绍了Twitter的解决方案,推出了路由代理的 ...

  5. 集群共享session;shiro实现session共享;springboot实现redis共享session;

    shiro实现共享session;springboot集成redis共享session;集群环境下shiro共享session 一.实现session共享 1. 聊聊session共享 2. shir ...

  6. Redis + Tomcat + Nginx 集群实现 Session 共享

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 作者 | 蕃薯耀 链接 | www.cnblogs.com/fan ...

  7. 分布式集群的Session问题

    1.Session的实现 在Session开始时候,分配一个唯一的Session标识sessionId,通过Cookie把 sessionId 告诉浏览器,以后每次请求的时候,浏览器都会带上 sess ...

  8. 深入浅出百亿请求高可用Redis(codis)分布式集群揭秘

    摘要:作为noSql中的kv数据库的王者,redis以其高性能,低时延,丰富的数据结构备受开发者青睐,但是由于redis在水平伸缩性上受限,如何做到能够水平扩容,同时对业务无侵入性是很多使用redis ...

  9. 用Redis存储Tomcat集群的Session(转载)

    本文转自http://blog.csdn.net/chszs/article/details/42610365 感谢作者 前段时间,我花了不少时间来寻求一种方法,把新开发的代码推送到到生产系统中部署, ...

最新文章

  1. mysql bin日志备份_mysql之binlog日志备份还原
  2. 租赁mt4虚拟服务器,mt4服务器出租
  3. 西门子标准报文1常用_基于Snap7使用C#编程访问西门子PLC系列教程(2)-S7协议
  4. 阿里安全猎户座实验室(Alibaba Orion Security Lab)简介
  5. 欧拉函数(简单介绍+例题)
  6. Docker : 数据卷(创建、挂载、查看、删除)
  7. Redis事务回滚深入
  8. 【转】Python学习路线
  9. illustrator 连接功能
  10. Oreilly.Python.Cookbook(3rd.Edition.May.2013)pdf
  11. 【车牌识别】基于matlab GUI BP神经网络车牌识别【含Matlab源码 669期】
  12. Java超详细的基础编程300题,附带答案,持续更新中~
  13. 外卖侠使用教程加体验地址
  14. 纸娃娃系统(摘自百科)
  15. VM player免费版安装
  16. React 18 超全升级指南
  17. 极点五笔烦人的几个快捷键.
  18. 基于阿里钉钉网页版制作绿色版客户端
  19. hdu2476 字符串A-字符串-B
  20. HP Gen8 MicroServer win7 系统安装手册(usb)

热门文章

  1. 基于Matlab的模拟通信实验平台设计,【通信原理仿真实验】通信原理虚拟实验仿真平台的设计和实现_玛雅作文网...
  2. 向量外积_解析几何 -向量
  3. mysql加锁语法_MySql 加锁问题
  4. c# ef报错_C# EF调用MySql出现“未将对象引用设置到对象的实例”错误解决方案
  5. python 温度 符号_Python通过小实例入门学习---1.0(温度转换)
  6. views 多个文件夹 netcore_.NET Core中的使用Kestrel服务器理解及应用
  7. python set |_Python事件类| set()方法与示例
  8. java接口并发衡量_java 后端设计高并发接口总结
  9. python实现实时监控_基于 Python 的交换机实时监控系统的设计与实现
  10. NAU8810相关问题