从一个BUG聊微信朋友圈设计

简介: 最近生活方式发生了一点变化。搬家了,住的地方离公司更近了。这就让我多了很多的操作空间,比如早上起来跑个步啥的。跑完步还能有点时间写博客,所以紧赶慢赶花了几个早上把这篇很早之前就想写的文章写出来了。平时也会积累一些写博客的灵感,后面慢慢写吧。过段时间打算想试试短视频的形式聊一些技术话题或者编程实战,计划中。。。

Y说

最近生活方式发生了一点变化。搬家了,住的地方离公司更近了。

这就让我多了很多的操作空间,比如早上起来跑个步啥的。跑完步还能有点时间写博客,所以紧赶慢赶花了几个早上把这篇很早之前就想写的文章写出来了。

平时也会积累一些写博客的灵感,后面慢慢写吧。

过段时间打算想试试短视频的形式聊一些技术话题或者编程实战,计划中。。。


一个权限bug

前不久无意间发现了一个微信朋友圈的权限bug。

事情是这样的,我平时会在微信朋友圈发点动态。

因为本人“过于羞涩”,所以很多动态都会一般会屏蔽公司的领导,偶尔也会屏蔽同事。比如偶尔写的公众号文章,也会屏蔽他们(防止他们发现我过于菜的事实)。

微信的朋友圈是支持这种简单的权限控制需求的,在发朋友圈的时候,可以选择:所有朋友可见、仅自己可见、不给谁看、只给谁看。

这种情况,我一般是设置不给带有“领导”和“同事”的标签看。

网络异常,图片无法展示
|

点击发送,没有任何问题,他们看不到这条动态。

直到我新加了一个同事的微信(以前没加过)。。。

我确定在加之前就给他设置好“同事”的标签,发现他居然能看到我发的那条动态!!!

网络异常,图片无法展示
|

这算bug吗?我觉得当然算啊!我明明“处心积虑”地设置好了权限不给同事看,结果新加的朋友可以无视这个设置,直接看到这条动态!

这让我又想起了之前加了一个同事,第二天她说我公众号文章写得不错。我内心一顿问号,心想我不是把你们屏蔽了吗???现在想来也是这个bug的锅了。


朋友圈的设计

因为这事,又想起了之前的一个编程设计题(其实是面试题):如果让你设计一个朋友圈,你会怎么设计?

设计一个朋友圈的功能不难,难的是如何能够在微信这么大的日活下维持高性能。常见的设计有两种:推模式和拉模式。适用于不同的场景。

所谓推模式,指的是一个用户发了一条动态,会把这条动态推送给所有朋友。这样每个人在刷朋友圈的时候,只需要把自己收到的动态按收到的顺序展示出来就行了。

网络异常,图片无法展示
|

所谓拉模式,指的是一个用户在刷朋友圈的时候,去请求他所有好友最近的动态,然后排序展示。

网络异常,图片无法展示
|

我们先来看看微信是怎么设计的。朋友圈目前有两个入口:

  1. 点击发现-朋友圈,可以看到自己的好友发的动态
  2. 点击某个好友的头像-朋友圈,可以看到这个好友的动态

对第一种业务场景,使用推模式比拉模式好,如果使用拉模式,我们要同时发出大量的网络请求,要处理某些请求失败的情况,拿数据之前要校验权限,拿到数据后要处理排序等。

而第二种业务场景,显然拉模式比推模式好。因为是查看一个单独的好友的动态,所以没有问题。


权限的设计

先来看产品层面的设计。我们在发朋友圈的时候,可以选择谁可见谁不可见。如果使用推模式,就很好控制权限了,直接把要推的人算出来,推给这些人就行了。其他人接收不到推送,自然也就看不到你发的这条动态了。

而众所周知,朋友圈一旦发表以后,内容是不可以修改的,权限也是不可修改的。所以也就不会有后续的权限变更维护问题。

网络异常,图片无法展示
|

按照这个逻辑,如果我在一分钟前发了一条朋友圈动态,然后新加了一个好友A,这个时候好友A的朋友圈是看不到我们刚刚发的这条动态的(即使他应该有权限),因为我们没有推给他,除非微信在加好友的时候做了补推的操作,我没试过,但估计没有做补推操作,感兴趣的读者可以做个实验看看有没有。

而如果好友A点击我的头像进入我的朋友圈,是能够看到我刚刚发的那条动态的。理论上来说,应该在拉的时候做一下权限校验,但很明显微信没有做。

这个权限校验其实并不复杂,也不需要很高的性能。我们用一个图来解释:

网络异常,图片无法展示
|

所以我理解这个并不是技术实现的问题,而是单纯的产品问题,没考虑到这个业务场景吧。但这个使用场景对于我来说确实是会经常遇到。不知道什么时候会修复,多久可以修复,但希望可以早点修复~


推模式有什么弊端?

最后再讨论一下推模式。推模式比较适合好友比较少的业务场景。在发动态这种业务下,一般有两种业务场景:

  1. 双向关注,比如微信好友,A和B是互相关注的关系,发的动态对方都能看到
  2. 单向关注,比如微博,A关注了B,那B发的动态A可以看到,但A发的动态B看不到。

如果是单向关注,那就不适合使用推模式,比如某大V,有好几千万粉丝,如果使用推模式,发一条动态就给这几千万人推送,那对服务器来说消耗巨大,不划算。所以这种单向关注的场景使用拉模式更适合

但单向关注有时候也会结合推模式和拉模式两种方式来做,设定一个阈值(比如1万),如果粉丝量小于这个阈值,就使用推模式,否则使用拉模式。

微信好友上限是5000人,所以全部使用推模式也还好。结合上面提到的权限问题,估计应该是使用的这种模式。但具体有没有其它什么实现,就不得而知了。

目录
相关文章
|
监控 前端开发 jenkins
新来个技术总监,给团队引入了这款开发神器,同事直呼哇塞
带团队时间久了,就能发现整个 Team 都渐渐疲了。前两年老板还专门买了个系统搞 OKR,现在也不大提了;Scrum 我们也搞了,用起来也就那样;项目管理工具试了好几个,禅道、Worktile、现在用 Coding,反正有一个能用的就行;微服务化改造从去年开始在吭哧吭哧搞,我们自己搞得觉得很厉害,但业务部门那边就觉得没啥差别,搞不懂你们研发部门每天在弄些什么,赶紧做我们提的需求要紧。
新来个技术总监,给团队引入了这款开发神器,同事直呼哇塞
|
程序员 前端开发
关于程序员写好 ppt 的几点总结
程序员日常工作中最多的应该是接收需求、编码实现需求。但也有些时候需要做一些非代码的文字工作。
146 0
关于程序员写好 ppt 的几点总结
|
存储 消息中间件 安全
「避坑宝典」为大家分享一下笔者在 2022 年所遇到“匪夷所思”的 Bug 趣事(上)
「避坑宝典」为大家分享一下笔者在 2022 年所遇到“匪夷所思”的 Bug 趣事(上)
105 0
|
开发框架 Java 测试技术
【测试基础】五、这样提bug单,开发小哥还会怼你么?
【测试基础】五、这样提bug单,开发小哥还会怼你么?
【测试基础】五、这样提bug单,开发小哥还会怼你么?
|
缓存 前端开发 JavaScript
淦!五行代码,难倒几十个前端群的小伙伴
淦!五行代码,难倒几十个前端群的小伙伴
136 0
淦!五行代码,难倒几十个前端群的小伙伴
|
UED 开发者 CDN
相亲交友源码,功能开发需要注意的四个要点
相亲交友源码,功能开发需要注意的四个要点
|
算法 架构师 Android开发
iOS开发者如何做到升职加薪到25k?6年开发 架构师笔记送给你!
对于我们绝大多数人来说,工作最基本的意义是我们可以通过自己的劳动换取酬劳来养活自己,尤其是对于刚毕业的学生,拥有一份全日制的工作意味着自己走出校园,踏上社会,自己真正开始独立起来。
iOS开发者如何做到升职加薪到25k?6年开发 架构师笔记送给你!
|
编解码 Unix Java
直播软件源码开发千万不能忘的一个知识点
对于直播软件源码开发的技术人员来讲,音视频即时通讯技术是需要熟练掌握的。毕竟像直播这样重视互动和实时性的应用场景,即时通讯可以从中起到很大的配合作用。目前市面上有很多服务商所提供的SDK可以帮助实现这一技术,但是在选择哪一家服务商时还需要多下一些功夫才行。本文主要分享一下开发过程中,音视频即时通讯会涉及哪些技术领域。
直播软件源码开发千万不能忘的一个知识点
|
数据可视化 前端开发 vr&ar
3D 真的很难吗,瞧瞧支付宝怎么做?
阿里妹导读:图像作为人类感知世界的视觉基础,是我们在这个信息化时代获取信息、表达信息及传递信息的重要手段,而生成图像最高效准确的方式就是由计算机生成、显示、绘制,这些技术又统称计算机图形技术。计算机图形技术已经是许多产业的技术基础,比如动画、影视特效、游戏、设计、广告、AR、VR、数据可视化等等。
5343 0
|
前端开发 程序员 数据库