在写之前,先说说当前的系统架构吧

spring cloud + zuul + eureka + oauth2 + redis + rabbitMq

这个系统是由我搭建的,当时采用的springCloud 版本 Finchley,这点是因为它支持springBoot2.0

注*

网关选zuul是因为当时对zuul比gateway更了解,而且用户量不是很大,现在zuul也遇到了问题,在考虑转gateway

RPC框架选eureka也是基于了解的情况选的,现在不更新了,以后会转Nacos

现有设计到的技术就上面那些了,很简陋.因为服务器采用的阿里云服务器,所以尽量在不扩展技术的情况下去做.

技术就说到这,接下来就是设计数据库表了 (最初版本:可能不是完整的字段)

首先是数据存储表:

CREATE TABLE `activity_record` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '动态id',
  `user_id` varchar(32) NOT NULL DEFAULT '' COMMENT '人员主键',
  `content` longtext NOT NULL COMMENT '内容',
  `time` datetime NOT NULL COMMENT '时间',
  `hot_spot_f` varchar(20) NOT NULL DEFAULT '' COMMENT '热点1',
  `hot_spot_s` varchar(20) NOT NULL DEFAULT '' COMMENT '热点2',
  `hot_spot_t` varchar(20) NOT NULL DEFAULT '' COMMENT '热点3',
  `dept_id` varchar(32) NOT NULL DEFAULT '' COMMENT '部门id',
  `is_delete` tinyint(1) NOT NULL DEFAULT 0 COMMENT '删除标志',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=21 DEFAULT CHARSET=utf8mb4 COMMENT='个人动态表';

CREATE TABLE `activity_like_record` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `user_id` varchar(32) NOT NULL COMMENT '用户id',
  `activity_id` int(11) NOT NULL COMMENT '动态id',
  `create_time` datetime DEFAULT NULL COMMENT '点赞时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COMMENT='点赞记录表';

CREATE TABLE `activity_comment` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `comment_info` varchar(400) DEFAULT NULL COMMENT '评论内容',
  `comment_time` datetime DEFAULT NULL COMMENT '评论时间',
  `parent_id` int(11) DEFAULT NULL COMMENT '父级评论id',
  `lev` tinyint(3) DEFAULT NULL COMMENT '评论等级',
  `user_id` varchar(32) DEFAULT NULL COMMENT '评论人',
  `activity_id` int(11) DEFAULT NULL COMMENT '动态id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COMMENT='评论表';

CREATE TABLE `activity_annex` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `annex_info` varchar(300) DEFAULT NULL COMMENT '附件信息',
  `annex_url` varchar(300) DEFAULT NULL COMMENT '附件路径',
  `annex_type` varchar(50) DEFAULT NULL COMMENT '附件类型',
  `activity_id` int(11) NOT NULL COMMENT '动态id',
  `sort` int(4) DEFAULT NULL COMMENT '排序',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8mb4 COMMENT='动态附件表';

CREATE TABLE `activity_record_draft` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '动态id',
  `user_id` varchar(32) NOT NULL DEFAULT '' COMMENT '人员主键',
  `content` longtext NOT NULL COMMENT '内容',
  `time` datetime NOT NULL COMMENT '时间',
  `hot_spot_f` varchar(20) NOT NULL DEFAULT '' COMMENT '热点1',
  `hot_spot_s` varchar(20) NOT NULL DEFAULT '' COMMENT '热点2',
  `hot_spot_t` varchar(20) NOT NULL DEFAULT '' COMMENT '热点3',
  `dept_id` varchar(32) NOT NULL DEFAULT '' COMMENT '部门id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8 COMMENT='个人动态草稿表';

CREATE TABLE `activity_annex_draft` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `annex_info` varchar(300) DEFAULT NULL COMMENT '附件信息',
  `annex_url` varchar(300) DEFAULT NULL COMMENT '附件路径',
  `annex_type` varchar(50) DEFAULT NULL COMMENT '附件类型',
  `draft_id` int(11) NOT NULL COMMENT '动态id',
  `sort` int(4) DEFAULT NULL COMMENT '排序',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8mb4 COMMENT='草稿动态附件表';

然后到了业务辅助表了,首先聊聊朋友圈架构设计(参考微信架构师许家滔在QCon北京2014上的演讲“微信后台存储架构”)

这里面有一个重要的思想: 时间轴-- 记录本人能看到的所有动态的时间线.

举个例子: 在做的时候原本思维是这样子的

在获取本人能看到的动态,需要查本人所有好友的动态后进行时间排序. 这个对时间复杂性了解的人应该知道在不考虑排序下时间复杂度是O(n)*O(m)

如果添加时间线的概念

针对于每个人都维护了一个时间线那么在任何情况下的时间复杂度都是 O(n) 但 空间上也多了O(n). 但多了个存储.

这是典型的空间换时间的思想

但在针对于公司内部动态中,动态都是可见的,所以在空间上还需要针对其它因素建立:

时间轴表:

CREATE TABLE `activity_timer` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `time` datetime NOT NULL COMMENT '时间',
  `activity_id` int(11) DEFAULT NULL COMMENT '动态id',
  `timer_type` tinyint(3) DEFAULT NULL COMMENT '时间轴类型 (主时间轴,个人时间轴,热点时间轴)',
  `timer_rel` varchar(32) DEFAULT NULL COMMENT '时间轴关联对象',
  PRIMARY KEY (`id`),
  KEY `type_rel` (`timer_type`,`timer_rel`)
) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=utf8mb4 COMMENT='时间轴表';

对于朋友圈扩展的热点:

CREATE TABLE `activity_hot_spot` (
  `id` int(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `hot_spot` varchar(10) NOT NULL DEFAULT '' COMMENT '热点',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `UN_HOT_SPOT` (`hot_spot`) USING HASH
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COMMENT = "热点";

热点模糊查询优化:

CREATE TABLE `activity_hot_spot_index` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `index_info` varchar(20) DEFAULT NULL COMMENT '索引字段',
  `hot_spot_id` int(11) DEFAULT NULL COMMENT '索引id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8mb4 COMMENT='热点索引表';

在此相关表设计完. 接下来就是流程设计

并不是很详细 以后补全 .

这块是设计思想,不是实际实现路线,

这边App那边是Java + kotlin 混合编写,而且对app缓存玩的不是很好,所以所有压力都塞给服务器.所以没有读取本地缓存这个步骤,所以缓存只有后端redis缓存

  

有关类朋友圈设计(3) -- 数据库设计&现有技术&流程设计的更多相关文章

  1. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(2)-数据库访问层的设计Demo

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(2)-数据库访问层的设计Demo ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1)框架搭建 前言:这 ...

  2. 2017.11.5 Java Web ----案例:数据库访问JavaBean的设计

    (12)案例----数据库访问JavaBean的设计 例题:数据库操作在一个Web应用程序中的后台处理中占有大比重,设计一组JavaBean封装数据库的基本操作供上层模块调用,提高程序的可移植性. [ ...

  3. 深度解读MRS IoTDB时序数据库的整体架构设计与实现

    [本期推荐]华为云社区6月刊来了,新鲜出炉的Top10技术干货.重磅技术专题分享:还有毕业季闯关大挑战,华为云专家带你做好职业规划. 摘要:本文将会系统地为大家介绍MRS IoTDB的来龙去脉和功能特 ...

  4. MRS IoTDB时序数据库的总体架构设计与实现

    MRS IoTDB时序数据库的总体架构设计与实现 MRS IoTDB是华为FusionInsight MRS大数据套件最新推出的时序数据库产品,其领先的设计理念在时序数据库领域展现出越来越强大的竞争力 ...

  5. QQ空间/朋友圈类界面的搭建

    类似于QQ空间的布局主要是在说说信息.点赞.回复三大部分的自适应布局上. 当我们需要搭建类似QQ空间.微信朋友圈的界面的时候,可做如下操作: 创建一个对应的model类: 创建一个对应model类的f ...

  6. iOS版微信朋友圈数据库的简要分析

    本文版权归cxun所有,如有转载请注明出处与本文链接,谢谢!原文地址:http://www.cnblogs.com/cxun/p/4550523.html 之前写了一些关于微信聊天记录的博文之后,不少 ...

  7. Visor 应用之一 通过ER 设计生成数据库脚本和实体对象

    前言 Visor(http://www.visor.com.cn)   是一个基于HTML5 Canvas 开发的IDE 框架和设计开发平台,有关Visor的设计架构和技术应用,在以后的文章里会逐渐跟 ...

  8. 以一个权限系统来告别WebForm —(一)项目整休架构设计与数据库设计

    在本节我想与大家与分享一下,我所将要做的权限系统的架构和数据库的表的设计.请各位大神们对我项目中设计的不足之处进行指导,让我得以更好的写完它,留给需要它的人. 我的项目架构如下图所示: 如上图所示,在 ...

  9. 物理数据模型(PDM)->概念数据模型 (CDM)->面向对象模型 (OOM):适用于已经设计好数据库表结构了。

    物理数据模型(PDM)->概念数据模型 (CDM)->面向对象模型 (OOM):适用于已经设计好数据库表结构了.   步骤如下: 一.反向生成物理数据模型PDM 开发环境 PowerDes ...

随机推荐

  1. 【动画消消乐|CSS】083.纯CSS实现卡通齿轮效果

    前言 Hello!小伙伴! 非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出-   自我介绍 ଘ(੭ˊᵕˋ)੭ 昵称:海轰 标签:程序猿|C++选手|学生 简介:因C语言结识编程,随后转入计 ...

  2. Qt Designer中自定义控件的使用(提升法与插件法)

    准备乱写一点Qt自定义Widget在Designer中的使用.可是又不想重复提升法(promotion)及插件法基本用法,因为Manual中Using Custom Widgets with Qt D ...

  3. JavaWeb项目实战-油画商城

    整个项目都已经上传到github-mmgallery上,供有需要的读者使用,主要文件来自于csdn,区别是csdn中的项目数据存储在MySQL中,本项目数据存储在Xml文件中.课件和学习视频课程来自M ...

  4. msfvenom简介

    写此文是因为网上资料杂乱,不方便查阅,辣眼睛 测试免杀的时候刚好用到这个功能,顺便写一下(0202年靠msfvenom生成的纯原生payload可以宣告死亡了,如果有查不出来的杀软可以退群了,这也叫杀 ...

  5. Node + Selenium 报错 UnhandledPromiseRejectionWarning: Error: ECONNREFUSED connect ECONNREFUSED 127.0.0.1:5319

    安装selenium-webdriver npm i selenium-webdriver 当前安装版本: "selenium-webdriver": "^4.0.0-a ...

  6. 怎样在自己的 Web 中加入强大的日志系统系统?slf4j 的日志插件必须要知道!

    对于程序猿来讲,一个应用程序的日志管理是极为重要的.因为,它可以帮助我们随时查看应用程序的运行状态.执行效果等信息,从而监控软件系统.或是根据日志信息解决一些重要的问题. 但是在 Java 应用程序中 ...

  7. 让div占据父元素剩下的所有位置

    场景模拟: 现在有一个父容器,里面有俩个div,左边的要给一个固定的200px的宽度,父容器剩下的宽度都归右边的div该怎么完成?HTML代码: <div class="wrap&qu ...

  8. 单例对象 (Singleton)设计模式

    单例的目的是为了保证运行时Singleton类只有唯一的一个实例,用于一些较大开销的操作. 饿汉式(没有线程安全问题): ' 由于使用static关键字进行了修饰,只能获取到一个对象,从而达到了单例, ...

  9. Spring第一课:基于XML装配bean(四),三种实例化方式:默认构造、静态工厂、实例工厂

    Spring中基于XML中的装配bean有三种方式: 1.默认构造 2.静态工厂 3.实例工厂 1.默认构造 在我们在Spring的xml文件中直接通过:     <bean id=" ...

  10. Struts2之国际化

    时间:2017-1-11 11:12 --国际化Struts2已经对国际化进行了封装,我们只需要根据其提供的API进行访问即可.要使用国际化的Action必须继承ActionSupport.1.什么是 ...