因为这些天离职换工作,调休期间有点时间所以把本网站后端代码重写了,提高了站点的响应时间。在文章访问计数有些心得。分享如下:
文章详情访问地址为: 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) # 永不过期
test