因为这些天离职换工作,调休期间有点时间所以把本网站后端代码重写了,提高了站点的响应时间。在文章访问计数有些心得。分享如下:
文章详情访问地址为: http://www/loonapp.com/blog/*/。 简单点的做法是直接在view方法(django, 其他框架如tornado为handle)时从数据库中取出该页面的访问次数加1。该做法在并发较大时候多数据库压力较大。因此采用将文章访问次数存到redis,当数量为N的整数倍则更新数据库,同时redis中key加1。 这样减少了这数据库n-1/n的压力, 也避免了因为大并发导致的数据库+操作锁问题def blog_view(request, blog_id):
"""
文章查看
:param request:
:param blog_id:
:return:
"""
BlogService.update_view_count(int(blog_id))
......# BlogService.py
@staticmethod
def update_view_count(blog_id):
"""
更新文章访问次数,计算准确访问次数的时候需要把这个也加上
:param blog_id:
:return:
"""
key_flag = 'blog_view_count_%d' % blog_id
view_count = cache.get(key_flag) # 使用django-redis-cache,settings中配置redis
if view_count != None:
cache.incr(key_flag) # 加1
if not (view_count % 10): # 当发现访问次数是10的倍数, 就更新数据库中文章访问次数
Blog.objects.filter(id=blog_id).update(view_count=view_count)
else: # 缓存中没有访问次数记录,则从数据库中获取
view_count = Blog.objects.get(id=blog_id).view_count
cache.set(key_flag, view_count+1, None) # 永不过期