因为这些天离职换工作,调休期间有点时间所以把本网站后端代码重写了,提高了站点的响应时间。在文章访问计数有些心得。分享如下:


文章详情访问地址为: 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)  # 永不过期


1条留言:
test 发表于 2017-10-20 10:34

test

您来留言:
Captcha