Memcached Tip 2:Session同步
http://memcachedproviders.codeplex.com/提供的Memcached客户端支持Asp.net站点中的Session同步,其原理是接管Asp.net的Session处理,同时在后台使用数据库支持完成WEB集群的Session的同步。具体实现步骤如下:
1:数据库准备
下载完毕Memcached providers之后,在解压目录下有:
一个用于创建数据库表,一个用于创建这个provider的需要用到的存储过程。
2:配置sessionState
sessionState的配置如下,为了完整性期间,这里给出Web.config的全部配置部分,包括分布式缓存的Memcached的配置:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | <?xml version= "1.0" ?> <!-- For more information on how to configure your ASP.NET application, please visit http: //go.microsoft.com/fwlink/?LinkId=169433 --> <configuration> <configSections> <section name= "cacheProvider" type= "MemcachedProviders.Cache.CacheProviderSection, MemcachedProviders" allowDefinition= "MachineToApplication" restartOnExternalChanges= "true" /> <sectionGroup name= "enyim.com" > <section name= "memcached" type= "Enyim.Caching.Configuration.MemcachedClientSection, Enyim.Caching" /> </sectionGroup> <section name= "log4net" type= "log4net.Config.Log4NetConfigurationSectionHandler,log4net" /> </configSections> <log4net> <!-- Define some output appenders --> <appender name= "ConsoleAppender" type= "log4net.Appender.ConsoleAppender" > <layout type= "log4net.Layout.PatternLayout" > <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!--<threshold value= "OFF" />--> <!-- Setup the root category, add the appenders and set the default priority --> <root> <priority value= "WARN" /> <appender- ref ref = "ConsoleAppender" > <filter type= "log4net.Filter.LevelRangeFilter" > <levelMin value= "WARN" /> <levelMax value= "FATAL" /> </filter> </appender- ref > </root> </log4net> <enyim.com> <memcached> <servers> <!-- put your own server(s) here--> <add address= "192.168.0.96" port= "11211" /> <!--<add address= "192.168.0.101" port= "11211" />--> </servers> <socketPool minPoolSize= "10" maxPoolSize= "100" connectionTimeout= "00:00:10" deadTimeout= "00:02:00" /> </memcached> </enyim.com> <cacheProvider defaultProvider= "MemcachedCacheProvider" > <providers> <add name= "MemcachedCacheProvider" type= "MemcachedProviders.Cache.MemcachedCacheProvider, MemcachedProviders" keySuffix= "_MySuffix_" defaultExpireTime= "2000" /> </providers> </cacheProvider> <connectionStrings> <add name= "ApplicationServices" connectionString= "Data Source=192.168.0.96;Initial Catalog=ForestFire;User Id=sa;Password=sa;" providerName= "System.Data.SqlClient" /> </connectionStrings> <system.web> <sessionState cookieless= "false" regenerateExpiredSessionId= "true" mode= "Custom" customProvider= "MemcachedSessionProvider" > <providers> <add name= "MemcachedSessionProvider" type= "MemcachedProviders.Session.SessionStateProvider,MemcachedProviders" connectionStringName= "ApplicationServices" dbType= "SQL" writeExceptionsToEventLog= "false" /> </providers> </sessionState> <compilation debug= "true" targetFramework= "4.0" /> <authentication mode= "Forms" > <forms loginUrl= "~/Account/Login.aspx" timeout= "2880" /> </authentication> <membership> <providers> <clear/> <add name= "AspNetSqlMembershipProvider" type= "System.Web.Security.SqlMembershipProvider" connectionStringName= "ApplicationServices" enablePasswordRetrieval= "false" enablePasswordReset= "true" requiresQuestionAndAnswer= "false" requiresUniqueEmail= "false" maxInvalidPasswordAttempts= "5" minRequiredPasswordLength= "6" minRequiredNonalphanumericCharacters= "0" passwordAttemptWindow= "10" applicationName= "/" /> </providers> </membership> <profile> <providers> <clear/> <add name= "AspNetSqlProfileProvider" type= "System.Web.Profile.SqlProfileProvider" connectionStringName= "ApplicationServices" applicationName= "/" /> </providers> </profile> <roleManager enabled= "false" > <providers> <clear/> <add name= "AspNetSqlRoleProvider" type= "System.Web.Security.SqlRoleProvider" connectionStringName= "ApplicationServices" applicationName= "/" /> <add name= "AspNetWindowsTokenRoleProvider" type= "System.Web.Security.WindowsTokenRoleProvider" applicationName= "/" /> </providers> </roleManager> </system.web> <system.webServer> <modules runAllManagedModulesForAllRequests= "true" /> </system.webServer> </configuration> |
3:代码
代码没有任何稀奇的,和传统的Session操作一样,如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | protected void Page_Load( object sender, EventArgs e) { try { Session[ "name" ] = "豆腐" ; } catch (Exception err) { Response.Write(err.Message); } } protected void Button1_Click( object sender, EventArgs e) { Label1.Text = Session[ "name" ].ToString(); } |
全部代码下载如下:WebApplication20110817.rar
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架