我有一些代码导致我的页面加载速度很慢(128 毫秒内有 49 个查询)。这是我网站的登陆页面——所以它需要快速加载。
以下是我的views.py,它在站点上创建了最新更新的提要,并导致我在调试工具栏中看到的加载时间最慢:
def product_feed(request):
""" Return all site activity from friends, etc. """
latestparts = Part.objects.all().prefetch_related('uniparts').order_by('-added')
latestdesigns = Design.objects.all().order_by('-added')
latest = list(latestparts) + list(latestdesigns)
latestupdates = sorted (latest, key = lambda x: x.added, reverse = True)
latestupdates = latestupdates [0:8]
# only get the unique avatars that we need to put on the page so we're not pinging for images for each update
uniqueusers = User.objects.filter(id__in = Part.objects.values_list('adder', flat=True))
return render_to_response("homepage.html", {
"uniqueusers": uniqueusers,
"latestupdates": latestupdates
}, context_instance=RequestContext(request))
导致最多时间的查询似乎是:
latest = list(latestparts) + list(latestdesigns) (25ms)
还有一个我也在调查的分别是 17 毫秒(站点范围的公告)和 25 毫秒(在每个产品提要项上添加标记项)。
有没有人看到我可以优化我的活动提要加载的任何方法?