[Twisted-Python] File persistence without blocking the main event loop?
Jean-Paul Calderone
exarkun at divmod.com
Mon May 18 07:21:58 MDT 2009
On Mon, 18 May 2009 08:31:56 -0400, Itamar Shtull-Trauring <itamar at itamarst.org> wrote:
>On Mon, 2009-05-18 at 19:34 +0800, Arun Thampi wrote:
>> Hi guys - I'm just beginning to learn about Twisted and was wondering
>> if there is a way to use the built-in Twisted persistence libraries
>> such as dirdbm etc. without blocking the main event loop? I read about
>> an approach which uses deferToThread (comment#3
>> here: http://code.activestate.com/recipes/413609/) but if you are
>> persisting quite often, doesn't the creation of threads on every
>> persist-call make it very expensive?
>
>deferToThread uses a threadpool, so it's not *very* slow. It does slow
>things down a bit, so it's better to do chunks of work rather than doing
>writes separately. That being said, writing to disk in main eventloop is
>often fast enough in practice, depending on how strong your latency
>guarantees need to be.
>
More importantly, don't use dirdbm. It's not a reliable data storage
library. In fact, you probably shouldn't use anything in twisted.persisted.
You might be interested in <http://www.divmod.org/trac/wiki/DivmodAxiom>.
Jean-Paul
More information about the Twisted-Python
mailing list