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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/397817.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何用计算机求和,求和计算器

求和计算器您可以使用此求和计算器快速计算预定范围内某个表达式的序列之和。如何使用求和计算器输入总和的表达式输入上限和下限提供表达式中使用的变量的详细信息单击“计算”按钮生成结果。求和Σ符号计算器k ∑n 0变量:nixyzabc 103740支持的运算符常量和函数算术运算符加“…

Zookeeper概述、特点、数据模型

Zookeeper1.Zookeeper概述Zookeeper是一个工具&#xff0c;可以实现集群中的分布式协调服务。所谓的分布式协调服务&#xff0c;就是在集群的节点中进行可靠的消息传递&#xff0c;来协调集群的工作。Zookeeper之所以能够实现分布式协调服务&#xff0c;靠的就是它能够保证分布…

云计算机创意名,有创意的道路名字推荐,分享一些好听有内涵的路名

提到龙岗板块&#xff0c;“风向”一直飘忽不定。原本地铁4号线今年通车&#xff0c;但是因为五象火车站的规划建设&#xff0c;暂时未开通;机场线已经敲定&#xff0c;然而没有龙岗的份…… [本文来自&#xff1a;www.777y.com]虽然机场线暂时无缘(可以期待下)&#xff0c;但是…

250W电源带i7+GTX1080?

电源的科学: Q1&#xff1a;电源的额定功率是什么&#xff1f;峰值功率又是什么&#xff1f;A1&#xff1a;电源的额定功率就是电源正常工作时的功率&#xff0c;它的值为用电器的额定电压乘以额定电流。而峰值功率指的是电源短时间内能达到的最大功率&#xff0c; 一般情况下电…

uml里的extend和include_用例图中包含(include)扩展(extend)和泛化(generalization)关系详解...

标签&#xff1a;uml用例图是解决用户需求的图&#xff0c;画好用例图一定要理清用例之间的关系。用例之间有三种关系&#xff1a;包含(include)扩展(extend)和泛化(generalization)。下面介绍三者的相同点和不同点以便区分&#xff1a;相同点&#xff1a; 三者都是从现有的用例…

数据库的数据类型及运算符

一、数据类型 1、整数类形&#xff1a; &#xff08;重点记忆&#xff0c;常用&#xff09;有符号整形&#xff1a;int--每个int类型的数据按4个字节存储&#xff0c;其中1位表示整数值的正负号&#xff0c;其他31位表示整数值长度和大小&#xff1b; 大整形&#xff1a;bigint…

浙江大学计算机博士很难复试专业课,浙江大学计算机学院2020年博士研究生招生复试公告...

一、复试资格通过计算机学院博士生材料初审的考生获得复试资格&#xff0c;名单见附件。二、复试内容和成绩组成博士研究生的复试内容主要包括对考生思想政治素质和品德、学术水平考核。1&#xff0e; 思想政治素质和道德品质考核思想政治素质和品德考核是博士研究生招生复试的…

推荐几款热门的敏捷开发工具

不知道有多少企业在很好的应用敏捷模式&#xff1b; 在今天的文章中&#xff0c;我们将一同了解更多有趣、高效且面向敏捷的项目管理工具。 Atlassian Jira/ Jira Agile   Atlassian的Jira是一款热门工具&#xff0c;用于追踪产品开发、帮助团队组织问题、分配工作并保证团队…

语言语法糖_【c#】几种常用语法糖

语法糖&#xff08;syntactic sugar&#xff09;是由英国计算机科学家Peter J. Landin发明的术语&#xff0c;指计算机语言中添加的某种语法。这种语法不影响语言的功能&#xff0c;但更方便使用。在开发中使用语法糖能够让程序变得更短&#xff0c;使看起来更美观些~空检查pub…

CodeForces 696B Puzzles

思维&#xff0c;简单树$dp$。 首先计算出每一个子树包含多少个节点&#xff0c;记为$f[i]$。然后就可以从$root$开始推出所有节点的期望了。 现在已知$fa$节点的答案为$ans[fa]$&#xff0c;假设要计算$fa$的一个儿子$v$的期望&#xff0c;那么$ans[v]ans[fa]1.0(f[fa]-f[v]-1…

2018清华计算机类专业录取分数线,清华大学2018年各省录取分数线及各专业录取分数线 - 高教网...

【一批录取分数线】港澳台联招&#xff1a;630分安徽&#xff1a;理科689分&#xff1b;文科675分&#xff1b;理科定向683分北京&#xff1a;理科694分&#xff1b;文科677分福建&#xff1a;理科681分&#xff1b;文科650分甘肃&#xff1a;理科652分&#xff1b;文科637分广…

ASP.NET 对类进行XML序列化和反序列化

1 序列化方法 public void SerializeObject<T>(string Xmlname,T t){XmlSerializer ser new XmlSerializer(typeof(T));TextWriter writer new StreamWriter(Xmlname);ser.Serialize(writer, t);//要序列化的对象writer.Close();} 2 序列化方法的使用 NodeConfigInfo n…

python100内3整除while_python-循环语句-习题及答案-for-while

for 变量 in range(起始&#xff0c;终止&#xff0c;步长):循环体变量 起始while 终止条件(bool):循环体步长break continue1. 盈盈为了考验令狐冲夺冠的决心&#xff0c;要他说一百遍“我能行&#xff01;”# for i in range(0,100,1):# print("我能行")2.本金100…

怎么用计算机连接电视,电脑怎么连接电视 详细步骤【图文】

现在一般的LED电视机都有连接电脑的功能&#xff0c;如何让电脑连接电视&#xff0c;让电视的大屏幕成为电脑的显示器呢?下面给大家说明电脑连接电视详细步骤!电脑连接电视步骤&#xff1a;1 电脑连接电视所需的接口及连接线我们先来介绍一下&#xff0c;电视上需要的接口&…

PC-CSS-多浏览器支持HTML5

非IE:article, section, aside, hgroup, nav, header, footer, figure, figcaption {display: block;}IE&#xff1a;<script>document.createElement(‘article’);document.createElement(‘section’);document.createElement(‘aside’);document.createElement(‘hg…

4r照片尺寸是多大_数码照片4D、4R、6RW是什么意思,怎样调整4D照片尺寸?

数码照片4D、4R、6RW是什么意思,怎样调整4D照片尺寸?数码相机和DV进入寻常百姓家&#xff0c;有些朋友希望把外出旅游或者居家时拍的照片冲印出来&#xff0c;但是一些朋友对里面的专业说法不太熟悉&#xff0c;比如3R,4R,4D,5D,5R,6R等照片的规格和尺寸不清楚&#xff0c;其实…

javascript 盒子模型

oDiv.clientWidth---》width左右padding oDiv.clientHeight---》height上下padding oDiv.clientTop---》上边框的高度 oDiv.clientLeft---》左边框的宽度 oDiv.offsetWidth---》clientWidth左右边框的宽度 oDiv.offsetHeight---》clientHeight上下边框的高度 offsetLeft---》当…

html自定义列表 嵌套,HTML 列表

HTML 支持有序、无序和定义列表:HTML 列表有序列表The first list itemThe second list itemThe third list item无序列表List itemList itemList item在线实例无序列表本例演示无序列表。有序列表本例演示有序列表。(可以在本页底端找到更多实例。)HTML无序列表无序列表是一个…

shiro会话监听_SpringBoot集成Shiro会话管理

在Shiro中我们可以通过org.apache.shiro.session.mgt.eis.SessionDAO对象的getActiveSessions()方法方便的获取到当前所有有效的Session对象。通过这些Session对象&#xff0c;我们可以实现一些比较有趣的功能&#xff0c;比如查看当前系统的在线人数&#xff0c;查看这些在线用…

JAVA程序员面试必知32个知识点

第一&#xff0c;谈谈final, finally, finalize的区别。 final 用于声明属性&#xff0c;方法和类&#xff0c;分别表示属性不可变&#xff0c;方法不可覆盖&#xff0c;类不可继承。finally是异常处理语句结构的一部分&#xff0c;表示总是执行。finalize是 Object类的一个方法…