Skip to main content

Memcached Caching

Tools
  • MemCacheD Manager v1.0.3.0 as Memcached Server
  • Enyim Memcached Client as Memcached .Net Client Library (Add these references to your project: Enyim.Caching.dll, log4net.dll, MemcachedProviders.dll)
  • Your Client Program
 MemCacheD Manager
  • Run the setup file and configure a Memcached Server as shown below:


Client Program
  • Create a new .Net project and add these settings to web.config file as shown below:
<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>


       <enyim.com>
             <memcached>
                    <servers>
                           <!-- put your own server(s) here-->
                           <add address="127.0.0.1" port="12345"/>
                    </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>


       <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>
                    <!--<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>
             </appender>
       </log4net>


  • Continue to add more settings data inside of <system.web> tag 
 
<sessionState timeout="1" cookieless="false" regenerateExpiredSessionId="true" mode="Custom" customProvider="MemcachedSessionProvider">
                    <providers>
                           <add name="MemcachedSessionProvider" type="MemcachedProviders.Session.SessionStateProvider,MemcachedProviders" dbType="None" writeExceptionsToEventLog="false"/>                        
                    </providers>
             </sessionState>

  • Add these references to your project: Enyim.Caching.dll, log4net.dll, MemcachedProviders.dll
  • Code your client program. Here is my sample program.

  • Here is the code behind:


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using MemcachedProviders.Cache;
using Enyim.Caching;

namespace WAMemcachedSessionTester
{
    public partial class _Default : System.Web.UI.Page
    {

        protected void btnEkle_Click(object sender, EventArgs e)
        {
            string strKey = TextBox1.Text;
            object objValue = TextBox2.Text;

            DistCache.Add(strKey, objValue);
            DropDownList1.Items.Add(strKey);
            Label2.Text = (string)DistCache.Get(strKey);

        }

        protected void btnGetir_Click(object sender, EventArgs e)
        {
            string strKey = null;
            strKey = DropDownList1.SelectedValue.ToString();
            Label1.Text = (string)DistCache.Get(strKey);

        }

        protected void Page_Load(object sender, EventArgs e)
        {
            Session["SessionTestBilgi"] = "Test Bilgi OK";

            if (Session["TIME"] == null)
            {
                Session["TIME"] = DateTime.Now;
            }
            Response.Write(Session["TIME"].ToString());
        }

        protected void btnSessionBilgisiGetir_Click(object sender, EventArgs e)
        {
            Label8.Text = "Session --->> " + Session["SessionTestBilgi"] + " && SessionID --->> " + Session.SessionID.ToString();
        }
    }
}

  • Deploy the client program to IIS.
  • Add a new Application Pool and name it as TestAppPool.
  • Change the client program's application pool to TestAppPool as shown below:


















  •  Run the client program and then stop TestAppPool and check if the same data is still coming. If yes, then this means you are getting the data from the Memcached Server.
Happy coding.

Comments

Post a Comment

Popular posts from this blog

How to fix Git push error: "RPC failed; curl 56 HTTP/2 stream 7 was reset send-pack: unexpected disconnect while reading sideband packet fatal: the remote end hung up unexpectedly"

Problem Today I saw the following problem when I tried to push my changes to a Git server after doing some work for upgrading an Umbraco v7 project to v8.18.8.  Possible reasons After some investigations, it seems like this could be because of the following reasons; Git is not happy with the amount of changes that are being pushed into the server.  There are possible limitations on the server about the size/amount of files that you can push. Your internet connection is not good and stable enough. Your Git client's version is old. Solution options For me, the easiest option was connecting to another Wifi and trying again. Apparently, this option helped quite a few people, so it is worth giving it a try. Unfortunately, it didn't work for me. A bad internet connection wasn't an option for me either, as my internet is pretty fast (500 Mbps). Similarly, my Git client version was the latest version (git version 2.41.0.windows.3).  On StackOverflow, there were a lot of recommendat

How to use JQuery Ajax Methods for Async ASP.NET MVC Action Methods

Making repeatedly calls to async methods can be a nightmare. In this case, it makes sense to use 2 ajax methods, instead of one. Here is a simple solution to overcome this problem. See that  ajaxcalls   is emptied after the success response for the first ajax call and then the second ajax method is used to make one single call to the async action method. Hope it helps. View: @section Scripts{     < script type ="text/javascript">         var smartDebitObject = new Object();         smartDebitObject.MembershipNumber = $( "#MembershipNumber" ).val();         smartDebitObject.ProfileId = $( "#ProfileId" ).val();         smartDebitObject.FirstName = $( "#FirstName" ).val();         smartDebitObject.LastName = $( "#LastName" ).val();         smartDebitObject.AddressLine1 = $( "#AddressLine1" ).val();         smartDebitObject.Postcode = $( "#Postcode" ).val();         smartDebitObject

How to fix "Microsoft SQL Error SQL71564: Error validating element [USERNAME]: The element [USERNAME] has been orphaned from its login and cannot be deployed."

I needed to export a database in BACPAC format today in order to restore it somewhere else, and I encountered the following error. To resolve this issue, I deleted all of the users mentioned in the error log. After successfully creating the BACPAC file, I used it to create a new database with no problems. Error: TITLE: Microsoft SQL Server Management Studio ------------------------------ One or more unsupported elements were found in the schema used as part of a data package. Error SQL71564: Error validating element [USER1]: The element [USER1] has been orphaned from its login and cannot be deployed. Error SQL71564: Error validating element [USER2]: The element [USER2] has been orphaned from its login and cannot be deployed. Error SQL71564: Error validating element [USER3]: The element [USER3] has been orphaned from its login and cannot be deployed. Error SQL71564: Error validating element [USER4]: The element [USER4] has been orphaned from its login and cannot be deployed. Error SQL71