Process Reloading Mechanism
When using daemon mode of mod_wsgi and the WSGI script file for your application is changed, the default behaviour is to now restart the daemon processes automatically upon receipt of the next request against that application. Thus, when making changes to any code or configuration data for your application, all you now need to do is touch the WSGI script file and the daemon processes for just that application will be automatically restarted and the application reloaded. This means that it is no longer necessary to send signals explicitly to the daemon processes, or restart the whole of Apache. This means that elevated privileges are not required by users and applications owned by other users in a shared hosting environment will not be affected when one users application is restarted.
Apache Authentication Provider
When using Apache 2.2, mod_wsgi provides the means to implement Apache authentication providers in Python. This means that password authentication for HTTP Basic and Digest authentication, plus other custom authentication mechanisms implemented by other Apache modules, can be delegated to your Python application. This for example can be used to implement HTTP authentication for a Trac instance against a user database maintained within a Django instance running on the same site. If using Apache 2.0 the mechanism is also available, but only in support of standard Apache HTTP Basic authentication.
Python Virtual Environments
More integrated support for Python virtual environments such as 'virtualenv' is now provided. These changes make it possible for different daemon process groups to be easily associated with distinct Python virtual environments. Where daemon process groups are being setup for different users, or to separate different applications, the use of Python virtual environments means that each can use different versions of modules or packages and not interfere with each other.
WSGI File Wrapper Extension
Support for 'wsgi.file_wrapper' extension has been added with operating system mechanisms such as sendfile() and mmap() being used when possible to speed up sending of any data back to a client. Provided an application is written to use this optional extension, then serving up of static files by the application should be greatly improved.
Daemon Mode Now Even Faster
Some underperforming code related to the socket used to communicate between the Apache child processes and the daemon processes has been replaced. This has result in a 40% improvement in base level performance for a simple hello world program. This means that daemon mode now performs even faster relative to competing solutions. Do remember though that the network level is usually never the bottleneck and it is the Python application and database queries where things slow down. Thus, although it is quicker, in the grander scheme of things the improvement wouldn't be noticed in most applications.
Congratulations, Graham. Something more to put on the pile of things to play with and use some more.
ReplyDeleteNice work, Graham. I've really been enjoying your work so far.
ReplyDeleteWow, seems like some nice new features in there. Definitely need to finish my Django book and test out mod_wsgi for it's deployment method.
ReplyDeleteCongratulations Graham - Clearly mod_wsgi 2.0 represents a lot of hard work and a major achievement!
ReplyDeleteI will be good on my promise to give it a go soon (jetfar.com).
Thanks for your work, Graham, and congratulations for your baby 1.0 !
ReplyDeleteThank you Graham. this is great, congratulations! Is it compatible with version 1.0? BTW. I made the changes you suggested to web2py and it now only uses absolute paths, in fact some users are successfully using it with mod_wsgi 1.0. Double thank you.
ReplyDeleteVery nice work. I was reading mod_wsgi.c source and it is quite beautiful. mod_wsgi currently is the best solution for python web apps.
ReplyDeleteGreat work!
The only improvement I want - docs. For me examing the source was needed to understand how several daemons will spawn for high loads. But after that whole workflow seems to be very clear. Awesome library!