入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

如何把session存储到数据库里

创建时间:2016-11-11 投稿人: 浏览次数:611
aspnet中,session默认以inproc模式存储,也就是保存在iis进程中,
这样有个优点就是效率高,但不利于为本负载均衡扩展。
可以把session信息保存在SQL Server中,
据说,该种方式比起inproc性能损失为10%-20%。如何实现呢,主要分两步介绍:
 
      1、初始化SQL Server中的状态数据库
 ASP.NET SQL Server 提供注册工具Aspnet_regsql.exe,用于创建供 ASP.NET 
中的 SQL Server 提供程序使用的 Microsoft SQL Server  数据库。
Aspnet_regsql.exe位于    /%windir%/Microsoft.NET/Framework/
<versionNumber>/aspnet_regsql.exe 目录下。如果麻烦,
可以 直接用visual studio tools 的命令提示工具中直接输入
aspnet_regsql.exe使用。用法如下:

    Aspnet_regsql.exe <options>
    可以用如下的语法来添加默认session数据库ASPState
    aspnet_regsql.exe -S localhost -U sa -P why1234? -ssadd -sstype p
    -S,-U/-P
     必须是大写,分别表示数据库服务器,用户名和密码。
    -ssadd / –ssremove 参数:
     -ssadd表示是添加Session数据库, -ssremove表示移除Session数据库.
创建自定义数据库myAppState,可以用如下的语法:
     aspnet_regsql.exe -S localhost -U sa -P why1234? -ssadd 
-sstype c -d myAppState
 
2、配置webconfig
    在webconfig的  <system.web>节下添加如下配置:
     <sessionState mode="SQLServer"  sqlConnectionString="server=
localhost; uid=sa; pwd=123456;"/>
   如果在初始化数据库的时候,创建了自定义数据库可以用类似于如下的的配置:
<sessionState mode="SQLServer"  allowCustomSqlDatabase="true" 
sqlConnectionString="server=localhost; DataBase=myAspState;uid=sa;
 pwd=123456;"/>
 
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。