zoukankan      html  css  js  c++  java
  • 项目实战:动态系统的设计(类似朋友圈)

    功能需求

    • 发布动态:类似朋友圈的功能,支持图片、文字、视频。
    • 读取动态:支持推荐、最新、最热等栏目。
    • 删除动态:支持发布者删除,运营删除(包括硬删除和软删除)。
    • 审核动态:需要有正常、审核中、封禁中等。
    • 动态送礼、点赞:支持给某条动态送礼、点赞。并且需要给发布者发消息。并且需要有消息列表,可以删除和一键清空。
    • 动态运营:运营可以置顶、推荐某个动态,还可以以运营身份发布官方动态。

    需求分析和初步设计

    考虑到发布动态的人群是主播,所以量不会很大,表的设计不用分表。

    动态页面的访问是很频繁的,所以在主页面如果有多张图则使用缩略图,否则使用原图,视频显示第一帧,剩下的交给CDN。

    接口读取的时候根据需求拉取动态ID,然后将每条动态的元数据缓存,加快接口速度。

    送礼和点赞,要考虑并发和效率,将发消息异步到队列慢慢处理。

    发消息方面,提供一个接口,在客户端第一次进入动态页时请求,获取是否有最新消息,后面则由客户端监听消息,来绘制新消息UI。

    数据库设计

    具体细节就不赘述了,大致有以下几张表:

    在这里插入图片描述
    值得注意的几点:

    • 点赞数和礼物数记录在主表,不要sum流水表。(减慢写,加快读
    • 所有表添加is_delete,表示软删除,涉及违规的才采用真删除,方便运营还原。

    代码设计

    总体来说这个功能是比较简单的,只是一个上传加查询的过程。

    需要注意的:

    • 将动态采用元数据缓存起来,一条动态一个,如果动态有修改直接更新该缓存,按照业务,一般设置3-7天过期就好了。
    • 首页排序提前用command命令计算好,不同的页面直接获取排好序的动态Id,然后点查缓存。主页可以不用缓存,只是全部拿缓存的过程。(整个返回值套缓存,第一是占redis内存,第二是拿全部出来再解析和直接点查效率差不多,第三是直接点查实时性更好。
    • 一旦后台有删除、封禁操作,将某个动态的缓存删掉就好了,当读不到缓存生成的时候判断is_delete即可。(不用直接执行command计算命令,第一是时间可能很长,第二是有些算法是根据时间来的,就是需要定期执行。
    • 如果点赞的量过大,可以考虑加消息队列,但是可能会存在ABA的问题。(点赞数忽上忽下
  • 相关阅读:
    带花树
    pxe+kickstart部署多个版本的Linux操作系统(上)---原理篇
    GO学习——安装编译(1)
    git学习——Github关联(2)
    你可能不知道的printf
    Linux中的文件查找技巧
    C语言入坑指南-被遗忘的初始化
    Linux常用命令-解压缩篇
    Linux常用命令-文本查看篇
    C语言的main函数到底该怎么写
  • 原文地址:https://www.cnblogs.com/HappyTeemo/p/15213734.html
Copyright © 2011-2022 走看看