当前位置: 移动技术网 > IT编程>开发语言>.net > NetCore入门篇:(九)Net Core项目使用Session及用Redis做分布式

NetCore入门篇:(九)Net Core项目使用Session及用Redis做分布式

2018年05月05日  | 移动技术网IT编程  | 我要评论

天天向上艾水水,大小爱吃 罗霈颖,王小予很淡定

一、简介


1、因为Net Core默认是没有启动Session功能的,如果需要使用,需要通过代码开启。

2、本篇说明如果启用默认Session实现,即Session存到内存中。

3、本篇扩展说明如何用Redis做Sessoin服务器,实现分布式。

 

二、开启默认Session功能


1、编写一个api,先写Session,再读取Session返回。

2、Startup未启动Session功能,查看效果,报错。

3、在Startup中添加两处启用Session代码,查看效果,正常。这里有知识点,UseSession需要写在UseMvc之前,否则会报错。

4、UseSession写在UseMvc之一,再查看效果,报错。

 

api代码

    public class OneController : Controller
    {
        public string GetString(string id)
        {
            HttpContext.Session.SetString(id, Guid.NewGuid().ToString());
            return HttpContext.Session.GetString(id);
        }
    }

 

未启用Session,查看效果

 

 

启用Session,代码简单,自己敲就行。

 

查看效果

 

 

 UseSession往后放

 

 查看结果,又出错了

 

 三、使用Redis做Session服务


 1、Net Core默认已经做了Session的Redis实现,只需要开启就可以了。

2、先要下载安装Redis,如果没有,就用楼主的就行了,连接在代码里,只是用来测试用。Redis默认是不需要用户名密码的。

3、再次是需要下载个Redis客户端,我使用的是RedisDesktopManager

4、在Startup中添加Redis配置信息。

5、查看运行效果:Session创建前后,Redis数据库的差异。

 

Startup配置代码

        public void ConfigureServices(IServiceCollection services)
        {
            //就这一行代码就行了。
            services.AddDistributedRedisCache(option => option.Configuration = "bitdao.cn:1012,abortConnect=false,connectRetry=3,connectTimeout=3000,defaultDatabase=1,syncTimeout=3000,version=3.2.1,responseTimeout=3000");
            services.AddSession();
            services.AddMvc();
        }

 

Session创建前

 

 访问API创建 Session

 

创建Session之后

 

 

四、Redis做Session服务的意义


1、Session的原理是在Cookies存一个SessionId。

2、分布式部署时,服务器A写一个Session时,只存在A服务器的内存中。用户第二次请求时,可能会访问到服务器B,只时候用SessionId去读取Session是空值。

3、如果用Redis做Session服务器,无论用户访问被分配到哪台服务器,都会用SessionId去Redis取Session,都能取到值。

见图如下

五、总结


 1、Net Core默认没有启动Sessoin,需要正确配置启动Session

2、分布式部署时,可以使用Redis做Session服务器,Net Core已经实现,一行配置代码即可。

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网