WebCaching framework
Note
This is a port of the old caching subsystem to the new uWSGI caching API documented here The uWSGI caching framework.Using the options here will create a new-style cache named “default”.
To enable web caching, allocate slots for your items using the cache
option. The following command line would create a cache that can contain at most 1000 items.
- ./uwsgi --socket 127.0.0.1:3031 --module mysimpleapp --master --processes 4 --cache 1000
To use the cache in your application,
- uwsgi.cache_set("foo_key", "foo_value") # set a key
- value = uwsgi.cache_get("foo_key") # get a key.
Persistent storage
You can store cache data in a backing store file to implement persistence. Simply add the cache-store <filename>
option.Every kernel will commit data to the disk at a different rate. You can set if/when to force this with cache-store-sync <n>
, where n
is the number of master cycles to wait before each disk sync.
Cache sweeper
Since uWSGI 1.2, cache item expiration is managed by a thread in the master process, to reduce the risk of deadlock. This thread can be disabled (making item expiry a no-op) with the cache-no-expire
option.
The frequency of the cache sweeper thread can be set with cache-expire-freq <seconds>
. You can make the sweeper log the number of freed items with cache-report-freed-items
.
Directly accessing the cache from your web server
- location / {
- uwsgi_pass 127.0.0.1:3031;
- uwsgi_modifier1 111;
- uwsgi_modifier2 3;
- uwsgi_param key $request_uri;
- }
That’s it! Nginx would now get HTTP responses from a remote uwsgi protocol compliant server. Although honestly this is not very useful, as if you get a cache miss, you will see a blank page.
A better system, that will fallback to a real uwsgi request would be
- location / {
- uwsgi_pass 192.168.173.3:3032;
- uwsgi_modifier1 111;
- uwsgi_modifier2 3;
- uwsgi_param key $request_uri;
- uwsgi_pass_request_headers off;
- error_page 502 504 = @real;
- }
- location @real {
- uwsgi_pass 192.168.173.3:3032;
- uwsgi_modifier1 0;
- uwsgi_modifier2 0;
- include uwsgi_params;
- }
Django cache backend
If you are running Django, there’s a ready-to-use application called django-uwsgi-cache
. It is maintained by Ionel Cristian Mărieș at https://github.com/ionelmc/django-uwsgi-cache and available on pypi.