News Feed
Sections




News Archive
Looking for more information on how to do PHP the right way? Check out PHP: The Right Way

Abhinav Singh's Blog:
How to use locks for assuring atomic operation in Memcached?
December 09, 2009 @ 11:20:42

In a new post to his blog Abhinav Singh shows you how to create a simple application that uses the memcached atomic increment command to help prevent concurrency issues.

Memcached provide atomic increment and decrement commands to manipulate integer (key,value) pairs. However special care should be taken to ensure application performance and possible race conditions while using memcached. In this blog post, I will first build a facebook style "like" application using atomic increment command of memcached. Also, I will discuss various technical difficulty one would face while ensuring atomicity in this application. Finally, I will demo how to ensure atomicity over a requested process using custom locks in memcached.

Example code is included to show how you can take a normal "store to memcached" example and modify it with the increment method to resolve issues that might come up from one or more scripts trying to get at the same values. He also includes an example of using locking to provide a similar effect.

4 comments voice your opinion now!
memcached atomic operation tutorial


blog comments powered by Disqus

Similar Posts

Benjamin Schneider's Blog: Use PHP's Tidy extension to validate your (X)HTML markup

SitePoint PHP Blog: Using the Google Analytics API with PHP: Logging In

NetTuts.com: Simplify Form Handling in a Big Way

Codewalkers.com: The PAVISE of Security

SitePoint PHP Blog: How to Install Custom PHP Extensions on Heroku


Community Events





Don't see your event here?
Let us know!


podcast community api framework tips bugfix library introduction laravel interview release package language opinion install series symfony deployment voicesoftheelephpant list

All content copyright, 2014 PHPDeveloper.org :: info@phpdeveloper.org - Powered by the Solar PHP Framework