设为首页 | 收藏本站欢迎来到卓越网络免费免备案CDN加速,DDoS和CC攻击防御,高防CDN管理平台!

已阅读

用上CDN加速每天发布十亿朋友圈

作者:cdnfine      来源:cdnfine      发布时间:2019-08-10
 
当你一秒钟拍了张自拍,一个小时修了下图,然后打开朋友圈,点击发送的那一刻。后台到底有多少工作在进行着?我们太习以为常,就没有意识到这背后还会有多复杂的逻辑。为什么每天几十亿量级的朋友圈发布量,都没有让微信崩溃过?我看了朋友圈负责人陈明的演讲,分享了微信的架构,数据结构设计等。很好看,很实在。但有的时候程序员讲话需要努力下才能理解。因此本文就是我从一个产品的角度,尽量平民化的阐述整个逻辑,写下的自己的思考和理解。希望任何对此有点兴趣,但同时又缺乏技术背景的人可以有所收获。

用上CDN加速每天发布十亿朋友圈

一:发朋友圈

1.CDN

当我们把精心修好的图,朋友圈点击发送。是不是有一种秒发零延迟的感觉?那是因为,我们在发朋友圈时,第一步动作是把你发布的图片传到腾讯就近的CDN节点,这时是不经过微信后台服务器的。所以会很快很快。(CDN这里就不展开了,可以想象下淘宝的菜鸟仓配网络一样。先把货发到仓配点,然后再配送给。)
 

2.发布表

当图片成功传到CDN后。这时微信客户端才会通知朋友圈CDN,说这里有个人发了个自拍耶。你发朋友圈时,很可能会屏蔽掉你EX或领导老板之类的对吧。所以呢,微信朋友圈的后台会把你发的图片、这个图片的URL地址、然后谁能看到这图片(很关键)等等信息写到发布表里。
 

3.相册表

当发布表写完后,会把你这自拍索引到你的相册表里。相册表实际上很小,因为它就存了个索引指针而已。也就是说,当你打开自己的相册列表看到你过去发的成百上千的照片时,都是根据索引去发布表里取的数据。
 

4.时间线

当相册表写好了。就会到一个很关键的步骤了。相册表写好,马上会触发一个批处理动作。就是会有个跑腿的,跑过去通知你所有的通讯录好友,说你发了个自拍。然后就会把你发的这个自拍插入到你好友的时间线里。当你好友刷新时,就会看到你的自拍了!Oh Yeah!当然这前提是,你的好友没有删除你、拉黑你、屏蔽你、不看你。扎心。我们后面会讲这些过滤的权限问题是怎么处理的。
 

二:刷朋友圈

好了。假设小王是你的微信好友。工作了五分钟累的不行了,休息休息刷下朋友圈。当小王点开朋友圈时,会拉他自己的时间线。这时他的时间线会得知有个你的新发布,小王的微信客户端会根据你的发布的元数据去CDN找这个图片的URL,拉到本地,然后小王就能看到你发的自拍了。

用上CDN加速每天发布十亿朋友圈

 

三:那删除、拉黑、标签、不让他看、三天可见该怎么办

1.谁可以看

当我们发朋友圈的时候,会有个谁可以看的选项。默认是公开,也就是你所有的好友(非删除、黑名单状态)都会看到。除此,还有部分可见和不给谁看的选项。这里就是第一步的权限控制。但这里控制的是,你发的这个照片,要加到哪些好友的时间线里。也就是说,假设你选择了不给“领导”标签下的人看。那领导标签下的所有人的时间线都不会加上你的这条新朋友圈。
 

2.标签这里要多说一句

标签实际上是帮助你更方便选择可见好友范围的一个东西。只有这一个作用。举个例子。比如说你发了自拍,选择“男神”标签发了出去。此时“男神”标签下有吴彦祖和古天乐两个人,那么吴彦祖和古天乐都能刷到你的自拍。这时呢,你又把刘德华加到“男神”标签下,刘德华是不会刷到你发的这张自拍的!同理,你渐渐厌倦了古天乐,把古天乐从“男神”标签里移了出去。古天乐依然可以看到你发的这个自拍哦。看明白了吧。你通过标签选择的可见范围,都是具体到标签下的人的。在你发布的那一瞬间,发布加到了谁的时间线里,就都定下来了。所以无论后面怎么调整标签下的人,都不会影响这条已经发出去的自拍了。
 
那你说,我就是不想让古天乐看我的这张自拍怎么办?好办,你可以选择删除他、拉黑他、不让他看、自拍设置成仅自己可见。
 

3.这就是第二步的权限控制了。

当小王刷朋友圈时。上面提到会更新他的时间线。这个时候,小王的客户端还会做一个事情。就是查一遍权限。也就是说,查一下时间线上的发布,有没有是属于不给小王看的。包括:删除、拉黑、不给他看、三天可见。这些都是可以随时变更设置的,因此小王每一次刷新朋友圈,时间线都会被筛选一下。
 
那就有宝宝说,会不会太麻烦了呀,每次都要查吗。实际上不太麻烦。因为首先在你发布时,就确定了要加到哪些好友的时间线里。因此小王在刷朋友圈时,不用去每个好友的相册里去捞,这相册还有可能存在几百个不同的服务器里。而只需要读自己的时间线这一个动作就行了,这样的话效率就高上天了。而删除、拉黑、不给他看、三天可见这些权限的设置,并不是说大家时时刻刻每天在改的东西。可能好久才改一次。因此小王的微信客户端一般会把这些权限数据缓存下来,不需要每次都去拉这个数据。只有变动的时候才去变更一下。所以,怎么说呢,问题不大。
 

四:评论和赞

理解了上面讲的整个发布表、相册表、时间线这些东西后。评论和赞就相对好理解了。微信后台会专门有张表存储评论和赞这些数据。假设三三是你和小王的共同好友,他刷朋友圈时,看到了你的这张自拍。那么会同时去评论表里拉这条发布的小王相关的评论和赞,放到这条朋友圈下面。如果不是你和小王的共同好友,那就看不到这评论和赞。
以上,就是整个发朋友圈、刷朋友圈整个的背后的一些东西。多去观察、思考下周围天天在用的东西,还是十分有益有意思的。
Keywords: 免费CDN加速 免备案CDN加速 高防CDN加速