点赞功能,你用 MySQL 还是 Redis ?
来源:SegmentFault
时间:2023-01-21 08:33:27 293浏览 收藏
亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《点赞功能,你用 MySQL 还是 Redis ?》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下MySQL、Redis、数据库、数据库设计、经验,希望所有认真读完的童鞋们,都有实质性的提高。
作者:一起web编程链接:www.toutiao.com/i6825148720728769028
点赞功能是目前app开发基本的功能
今天我们就来聊聊 点赞、评论、收藏等这些场景的db数据库设计问题。
1. 我们先来看看场景的需求:
- 显示点赞数量
- 判断用户是否点过赞,用于去重,必须的判断
- 显示个人点赞列表,一般在用户中心
- 显示文章点赞列表
我们先看一下头条和微博的例子
这两个都是具有顶级流量的,后端肯定有复杂的架构,我们今天只谈大众化的方案。
方案
2.1 mysql方案
mysql方案, 随着nosql的流行,大数据的持续热点,但是mysql仍然不可替代,对于大多数的中小项目,低于千万级的数据量,采用mysql分表+cache,是完全可以胜任的,而且稳定性是其他方案无可比拟的:
-- 文章表 create table post { post_id int(11) NOT NULL AUTO_INCREMENT, ...... star_num int(11) COMMENT '点赞数量' } -- 用户表 create table user { user_id int(11) NOT NULL AUTO_INCREMENT, ...... star_num int(11) COMMENT '点赞数量' } -- 点赞表 create table star { id int(11) NOT NULL AUTO_INCREMENT, post_id, user_id, ...... }
常用的查询:
查询用户点赞过的文章
//以文章id=888为例 127.0.0.1:6379[2]> set star:tid:888 898 //设置点赞数量 OK 127.0.0.1:6379[2]> incr star:tid:888 //实现数量自增 (integer) 899
场景b:点赞去重,避免重复点赞
要实现这个需求,必须有文章点赞的uid列表,以uid为key场景c:一般在用户中心,可以看到用户自己的点赞列表
这个需求可以使用场景b的数据来实现。
场景d:文章的点赞列表,类似场景b,以文章id为key
//以文章id=888为例 127.0.0.1:6379[2]> sadd star:list:tid:888 123 456 789 //点赞uid列表 (integer) 3 127.0.0.1:6379[2]> sismember star:list:tid:888 456 //判断是否点赞 (integer) 1
点赞的地方,如果点赞过显示红色,没有则显示黑白色,
今日头条是没有地方可以看到点赞列表的,而微博点进去,详情页可以看到点赞列表,但是只会显示最近的几十条,没有分页显示。
如下图,我选了一条热点,拥有众多粉丝的“猪猪”
可能有人觉得,点赞列表没人关心,存储又会浪费大量资源,不如不存!但是,这个数据是必须要有的。两点:
a. 去重。点赞数可以不精确,但去重必须是精确的,
b.另外一个社交产品,用户行为的一点一滴都需要记录,对于后续的用户行为分析和数据挖掘都是有意义的。
上面使用string存储的用户点赞数量,除了string,还可以用hash来存储,对文章id分块,每100个存到一个hash,分别存入hash table,每个文章id为hash的一个key,value存储点赞的用户id,如果点赞用户很多,避免id过多产生性能问题,可以单列出来,用sorted set结构保存,热点的毕竟是少数。
方案优缺点比对
hash:使用了更少的全局key ,节省了内存空间;但是也带来了问题
如何根据文章id路由到对应的hash?
查找一个用户id是在hash还是set?存在不确定性
使用hash虽然节省了空间,但增加了复杂度,如何选择就看个人需求了。
除此之外,你还有其他的方法吗?
3. 数据一致性
redis作为storage使用时,一定要做好数据的持久化,必须开启 rdb 和 aof,这会导致业务只能使用一半的机器内存,所以要做好容量的监控,及时扩容。
另外只要有数据copy,就会有一致性问题,这就是另外一个很重要的话题了。以后有时间再细聊吧!
写在最后:把问题写明白,真不是一件容易的事情,请大家多多关注,留言,谢谢!
前几天写的一篇文章,受到众多同行的热情回复,能和众多同行一起交流,深感荣幸!对于工程类问题,没有标准的方案,一千个人有一千个方案,哪个最适合你只有你自己知道!期待你更好的思路和方法。
微信搜索:【Java小咖秀】更多精彩等着您~
回复手册获取博主15万字Java面试通关手册&1.4万字Linux命令实战书册~
本篇关于《点赞功能,你用 MySQL 还是 Redis ?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!
-
499 收藏
-
286 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
184 收藏
-
237 收藏
-
210 收藏
-
192 收藏
-
364 收藏
-
373 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 玩命的滑板
- 这篇技术贴出现的刚刚好,太全面了,受益颇多,已加入收藏夹了,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-02-10 04:57:31
-
- 拼搏的煎饼
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者分享技术文章!
- 2023-02-05 17:44:42
-
- 俊逸的小熊猫
- 太全面了,已收藏,感谢作者的这篇博文,我会继续支持!
- 2023-01-27 07:05:06
-
- 典雅的黑夜
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享博文!
- 2023-01-25 19:57:44
-
- 动人的小懒猪
- 这篇文章内容太及时了,细节满满,很有用,mark,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-23 00:19:41