<?xml version="1.0" encoding="utf-8"?>
<feed xml:lang="en-us" xmlns="http://www.w3.org/2005/Atom"><title>Simon Willison's Weblog: contextmanager</title><link href="http://simonwillison.net/" rel="alternate"/><link href="http://simonwillison.net/tags/contextmanager.atom" rel="self"/><id>http://simonwillison.net/</id><updated>2010-02-01T10:15:02+00:00</updated><author><name>Simon Willison</name></author><entry><title>Distributed lock on top of memcached</title><link href="https://simonwillison.net/2010/Feb/1/distributed/#atom-tag" rel="alternate"/><published>2010-02-01T10:15:02+00:00</published><updated>2010-02-01T10:15:02+00:00</updated><id>https://simonwillison.net/2010/Feb/1/distributed/#atom-tag</id><summary type="html">
    
&lt;p&gt;&lt;strong&gt;&lt;a href="http://amix.dk/blog/post/19386"&gt;Distributed lock on top of memcached&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;
A simple Python context manager (taking advantage of the with statement) that implements a distributed lock using memcached to store lock state: “memcached_lock can be used to ensure that some global data is only updated by one server”. Redis would work well for this kind of thing as well.


    &lt;p&gt;Tags: &lt;a href="https://simonwillison.net/tags/concurrency"&gt;concurrency&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/contextmanager"&gt;contextmanager&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/locking"&gt;locking&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/memcached"&gt;memcached&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/plurk"&gt;plurk&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/python"&gt;python&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/redis"&gt;redis&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/with"&gt;with&lt;/a&gt;&lt;/p&gt;



</summary><category term="concurrency"/><category term="contextmanager"/><category term="locking"/><category term="memcached"/><category term="plurk"/><category term="python"/><category term="redis"/><category term="with"/></entry></feed>