I'm migrating my tumblr blog to docpad and have started with this boilerplate: https://github.com/ervwalter/ewalnet-docpad
Now my problem is that "docpad run" takes 58s to run, and a livereload run takes 23s. I wrote the author of this boilerplate and he says he is having the same, but it doesn't bother him too much.
But I don't want to wait half a minute for every change in a blog post to see how it looks like, so I'm trying to make it faster. I tried profiling with nodetime but I don't see a drilldown per method or so. My assumption is that the time is lost in the partials, at it sends the whole posts to the partials
How can I profile Docpad so I see where the time is lost? I know the question is very broad, but all I found on performance optimizing on DocPad is that you should make Docpad not to parse static files.
Update the missing link was that I needed to start the CPU profiler
on nodetime:
CPU profiler
on nodetimedocpad --profile run
Unfortunately in my case the output is not much helping. The results of my run reveal that 81% of the time is spent in ambi.js
, which seems is just a intermediate layer which calls functions. I could not find out which functions are called, adding console.log(fireMethod.toString())
I only see
function () { [native code] }
so I'm not really further. How can I find out where the time is actually spent? For reference: here is my v8.log
Also, I'm a bit worried, that docpad almost only relies on modules written by Benjamin Lupton. Why is that so?
After an odyssey of about 1 week I came to the conclusion that Docpad is not made for speed, it is made to handle complex sites. Some facts:
My use case is writing articles for a blog and I have a lot of "change text and see how it looks" loops. I have switched to Hexo which is a lot faster:
hexo server
starts in 2.5 seconds. With livereload
on, when I change a blog post, the broswer tab reloads the page and shows the new content in about 1shexo clean
and hexo generate
takes only 5s.This is the same setup (with less
, coffeescript
, etc.) I had for DocPad where DocPad needed 38s to run.
Additionally to speed hexo gave me
<! --more -->
is supported out of the boxOverall, it looks like hexo is suited better for blogs, whereas docpad is better suited for more complex sites. Hexo looks like it's really taking off, getting about 30 stars on github per week, whereas docpad is only getting about 10 stars per week.