<?xml version="1.0" encoding="utf-8"?>
<feed xml:lang="en-us" xmlns="http://www.w3.org/2005/Atom"><title>Simon Willison's Weblog: with</title><link href="http://simonwillison.net/" rel="alternate"/><link href="http://simonwillison.net/tags/with.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><entry><title>Richard Jones: Something I'm working on...</title><link href="https://simonwillison.net/2009/Aug/7/something/#atom-tag" rel="alternate"/><published>2009-08-07T15:47:00+00:00</published><updated>2009-08-07T15:47:00+00:00</updated><id>https://simonwillison.net/2009/Aug/7/something/#atom-tag</id><summary type="html">
    
&lt;p&gt;&lt;strong&gt;&lt;a href="http://www.mechanicalcat.net/richard/log/Python/Something_I_m_working_on.3"&gt;Richard Jones: Something I&amp;#x27;m working on...&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;
Python’s with statement appears to provide just enough syntactic sugar to create some really interesting DSL-style APIs—here’s a very promising example for laying out GUI applications.


    &lt;p&gt;Tags: &lt;a href="https://simonwillison.net/tags/dsl"&gt;dsl&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/gui"&gt;gui&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/python"&gt;python&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/richard-jones"&gt;richard-jones&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/with"&gt;with&lt;/a&gt;&lt;/p&gt;



</summary><category term="dsl"/><category term="gui"/><category term="python"/><category term="richard-jones"/><category term="with"/></entry></feed>