How would I go about speeding up Django template rendering? My template takes about 1-2 seconds or so to render, after the view function fully computes whatever it needs to.
I just spent a good deal of time optimizing my django templating code. Below are optimization guidelines that worked for me, but depending on your setup, you may not get as significant of a speedup.
unicode
, not str
: Django coerces all variables to unicode. This doesn't take too long to do, but if a str
variable is being used in many places in your templates, it can turn into a noticeable delay. This is very easy to fix, whenever you're sending text data to a Django renderer, make sure it's unicode.safe
: Django's automatic security measures are really nice, but they do come with a small performance hit. If you're using many variables in your template, and you know that it's safe, then be sure to mark it as such.render_template_from_string
, django pulls the template, compiles it, and then renders it. Django makes it easy to cache the first two parts of this process and store them in memory. All you need to do is make one small change in your settings.py
file to add cached.Loader
to your TEMPLATE_LOADERS
. More is explained in the Django documentation.endless pagination
: I found that the endless pagination plugin slowed things down extremely. That's because it has to load a new template for every single page number. I went in and hacked at it until I got it doing what I wanted, but before you do that, try removing it and see what type of performance improvement you get.Doing the above cut my rendering time of a complex page on a GAE instance from about 1.0S to 250ms, but again, your mileage may vary.
I would recommend as Step 0 adding to your Django Debug Toolbar an extra panel called Django Toolbar Template Timings. It told me exactly how much time was being spent in each template (block, etc), and how much of that time is in SQL. It's also extra validation that this is your problem.
Here's how to add a panel to Debug Toolbar. http://django-debug-toolbar.readthedocs.org/en/latest/configuration.html#debug-toolbar-panels
Another trick I found: I had to display an HTML table of 755 rows * 15 columns (filling a total of 11,325 data).
That page used to delay for about 25/30 seconds loading and then the page was a bit laggy. What I did was setting the table with display:none
and after the page was fully loaded, changed the CSS property with JavaScript.
After all of that, the page is loading in max 6 seconds. I suppose that Django spends much less time rendering non-visible elements.
I do not know if it only works in my case, but it seems to be.
Use ManifestStaticFilesStorage to serve your static files. The performance boost I've witnessed relative to using CachedStaticFilesStorage with the default LocMemCache
is immense. The difference being no hashes ever need to be calculated at runtime.
I don't quite know why the difference is as huge as it is - while it's true that CachedStaticFilesStorage
would initially need to calculate hashes and fill the cache, once the cache is filled I wouldn't expect a significant performance penalty relative to the manifest method. But it is massive, and the documentation also recommends using ManifestStaticFilesStorage
for performance.