durusmail: quixote-users: mod_python, quixote, reloads
mod_python, quixote, reloads
2003-03-17
2003-03-18
2003-03-18
2003-03-18
2003-03-20
2003-03-20
Re: mod_python, quixote, reloads
2003-03-21
2003-03-20
2003-03-18
mod_python, quixote, reloads
Titus Brown
2003-03-20
->   greg> On 17 March 2003, David Ascher said:
->   >> Has anyone come up with a way to get quixote modules to get reloaded
->   >> when they've been modified when running under mod_python?
->
->   greg> I have been down that road several times in the past, and it
->   greg> *always* ended in tears.  Module reloading is a convenient little
->   greg> hack in an interactive interpreter, but in a real-world long-lived
->   greg> process, it is always doomed to failure.  Always.
->
-> It works in -- among others, I'm sure -- Erlang, Smalltalk, and Common
-> Lisp long-running processes; I'm curious about which Python features or
-> semantics (or implementation details, for that matter) prevent it from
-> accomplishing this attainable goal. (It really is a very nice capability
-> to have, obviously.)

Hi, Kendall,

the Python module system is kind of hacked together, and (as I found out with
PyWX) isn't really designed for long-running Python systems with multiple
interpreters and processes.  It works very well, mind you, but it's hard
to munge in a consistent way.

In particular,

* there is an underlying caching layer that is per-Python-instance, not
        per-interpreter or per-thread; a cached version is initialized for
        each newly imported module.

        On initial import, and (I think) on 'reload', top-level statements
        are executed.  The results of these statements are cached and
        used to create the per-interpreter copies.

* there is a separate caching layer for each interpreter; this is why you
        need to do a 'reload'.

* modules are mutable, but changes are not passed across interpreters.

So, if you're willing to assume that modules are read-only after import,
and that functions executed on import are time-invariant, you can 'reload'
modules with impunity.

I'm not sure how this would interact with PTL stuff, but I assume it's no
different.

The situation is complicated by the multiple strategies that are used for
persistent Python interpreters:

* CGI uses non-persistent instances of the Python runtime environment;

* mod_python uses multiple, persistent instances of the Python runtime
        environment, as does SCGI, I think;

* PyWX uses one instance with multiple interpreters;

* Python itself when doing Web serving can use multiple threads, but all
        in one persistent Python runtime environment.

Because of the different levels of caching, I find it very difficult to
come up with a strategy that guarantees identical behavior across all
of these options without restricting the design of modules.

cheers,
--titus

reply