即时通讯是目前internet上最为流行的通讯方式,各种各样的即时通讯软件也层出不穷,那么今天主要针对QQ好友在线状态/QQ群友在线状态功能出发,一起思考其中的实现原理以及我们如何去测试此功能?

当大家在使用QQ的时候,是否和我一样有如下疑问:

在好友列表中为什么可以实时的看到qq好友的在线、离线等状态?

在QQ群的群友列表中能看到当前群友的在线、离线等状态,是如何实现的?

作为测试工程师究竟该如何去测试里面用到的技术?

我带着这些问题,去搜集了一些资料进行了解、学习和总结后,现分享给大家。

关于QQ好友在线/离线状态我所理解的流程是:

当用户A登录成功时,服务器要把用户A的在线状态(online)写到缓存(高可用的缓存集群里);userid-A—》login—》server—》set status in cache(userid:online)

当用户A下线(登出)时,服务器要找到用户A的缓存将在线状态(online)变成离线状态(offline);userid-A—》loginout—》server—》update status in cache(userid-A:offline)

其他所有用户的状态都会存储在缓存中,所以当用户A登录时,从数据库中查出用户A的好友,再从缓存中查出这些好友所对应的在线状态,从而用户A可以看出哪些好友在线哪些好友离线;

userid-A—》my friends status—》get friends userids in DB —》get userids status in cache(userid1:online,userid2:offline,userid3:offline,userid4:online……)

针对上面的流程主要考虑的测试点如下:

无缓存情况下,用户A登录时,写入缓存正常(缓存大家应该都了解过,比如memcache、redis等如何查看缓存?不会的同学可以咨询也可自己查下相关资料)

当用户退出登录时,缓存中对应的value被置为offline;

缓存存的有效期校验;

用户A的好友用户B下线/上线时,状态是否显示正确;

用户A的多个好友中有在线有离线的,当用户A查看好友状态时,状态显示是否正确;

当redis连接异常或超时时,应该如何处理;

等等...大家可以想想需要测试的功能点,要了解开发实现的过程,尽可能的去覆盖测试点。

写到这里,其实其中还有一个重要的点:比如用户A的好友用户B在线,突然,用户B离线了,那么用户A能否立即看到好友由在线变成离线呢?这也是我们测试人员需要考虑的功能点!到底是不是实时的我也不能确定,如果有人知道的话可以分享下。如果对实时性要求较高,可以采用推送的方式同步,如果实时性要求不太高的话,可以采用轮询拉取的方式进行同步。

再普及下轮询拉取方式和推送方式,如下:

什么是轮询拉取方式

举例说明:用户userid-A要看到好友的在线状态的话,比如就要每分钟轮询向服务器拉取全部好友的在线状态。缺点就是:有一分钟的延迟,同时当好友的状态期间没有变化时也请求服务器拉取产生大量的无效请求暂用服务器的资源。这种方式可能大家在工作中也经常用到,不断的轮询获取服务器的信息。

什么是推送的方式

继续举例说明:还是用户userid-A要看到好友用户userid-B在线状态的话,当用户userid-B下线时,由在线变成离线(更新缓存为offline),同时要将这个状态改变的通知推送给用户userid-B的在线反向好友。这样就变成实时了,但是缺点就是:在线好友量大的话,任何一个用户状态的改变会扩散很多实时通知,需要考虑承载能力。

大家可以思考下,QQ群友的在线同步应该是怎样的流程呢?到底是使用轮询的方式还是推送的方式呢?后续如果有时间的话可以继续讨论。

测试架构师论坛:http://www.youxitest.com


了解更多请关注微信公众号:测试架构师

                                                                      


QQ好友在线/离线,怎么测试?的更多相关文章

  1. QQ群友在线/离线,如何测试?

    上篇文章『QQ好友在线/离线,如何测试?』针对即时通讯的"状态"进行了分析和总结,主要说到了QQ好友在线/离线实现方案,测试过程中需要注意的测试点. 针对好友状态实时性的要求需要使 ...

  2. ExpandableListView仿QQ好友列表

    本例中,对ExpandableListView中的数据进行了封装,分为两个JavaBean,一个为Group类表示组信息,一个Child类表示该组下子列表信息: Group: public class ...

  3. QQ好友状态,QQ群友状态,究竟是推还是拉? 网页端收消息,究竟是推还是拉?

    https://mp.weixin.qq.com/s/KB1zdKcsh4PXXuJh4xb_Zw 网页端收消息,究竟是推还是拉? 原创 58沈剑 架构师之路 2020-12-28   https:/ ...

  4. Ubuntu14.04用apt在线/离线安装CDH5.1.2[Apache Hadoop 2.3.0]

    目录 [TOC] 1.CDH介绍 1.1.什么是CDH和CM? CDH一个对Apache Hadoop的集成环境的封装,可以使用Cloudera Manager进行自动化安装. Cloudera-Ma ...

  5. ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(九) 之 用 Redis 实现用户在线离线状态消息处理(一)

    前言 上一篇中简单讲解了用Redis缓存在线用户逻辑.篇幅也比较小,本篇将详细实现用户的上线下线通知.图片效果转换功能.而且,代码和开发思路都会详细介绍. 效果展示 目前有三个用户,user1,use ...

  6. iOS开发UI篇—使用UItableview完成一个简单的QQ好友列表(一)

    iOS开发UI篇—使用UItableview完成一个简单的QQ好友列表(一) 一.项目结构和plist文件 二.实现代码 1.说明: 主控制器直接继承UITableViewController // ...

  7. (二十七)QQ好友列表的实现

    QQ好友列表通过plist读取,plist的结构为一组字典,每个字典内有本组的信息和另外一组字典代表好友. 要读取plist,选择合适的数据结构,例如NSArray,然后调用initWithConte ...

  8. Centos7中在线/离线安装DockerCE最新版

    Docker在Centos7在线/离线安装 一.在线安装 1.检查系统是否支持,因为Docker 要求 CentOS 系统的内核版本高于 3.10 uname -r 2.确保 yum 包更新到最新 y ...

  9. 让QQ好友现形

    方法一 现在使用QQ的朋友,越来越注重保护自己的个人信息,如果对方将个人资料设置为保密你就无法看到对方的资料了,而这位好友如果又有着不断变换昵称的不良习惯,那么随着QQ好友名单的不断增加,时间一长,你 ...

随机推荐

  1. Android开发知识体系总结

  2. 源码(06) -- java.util.AbstractList<E>

    java.util.AbstractList<E> 源码分析(JDK1.7) ------------------------------------------------------- ...

  3. CSS3知识点整理(四)----布局样式及其他

    包括CSS3多列布局样式.Flexbox伸缩布局.盒子模型等.重点介绍了Flexbox伸缩布局的各种属性用法. 一.多列布局 为了能在Web页面中方便实现类似报纸.杂志那种多列排版的布局,W3C特意给 ...

  4. C# 6 与 .NET Core 1.0 高级编程 - 39 章 Windows 服务(下)

    译文,个人原创,转载请注明出处(C# 6 与 .NET Core 1.0 高级编程 - 39 章 Windows 服务(下)),不对的地方欢迎指出与交流. 章节出自<Professional C ...

  5. iptables 完成联网控制 (续) ,独立native进程监听。

    上一篇:http://www.cnblogs.com/oscar1011/p/5243877.html 之前做的iptables 来进行的联网控制,一直耿耿于怀,想要知道系统里的netd等等是如何做到 ...

  6. C++STL笔记

    C++STL 1.vector 向量,长度可变的数组 头文件 #include<vector> 1.1vector的定义 vector<typename> name; 例如: ...

  7. Java三大修饰符

    1.static 修饰: 修饰属性:类变量,全类共有 修饰方法:静态方法,静态方法中不能直接访问非静态的方法和属性 静态方法只能被静态方法覆盖,并且没有多态 静态的方法或者属性不依赖于对象:类名.方法 ...

  8. GDKOI2015滚粗记

    又是愉悦的滚粗了hahaha(特别不甘心啊啊啊) 其实去比赛每次都一样啦,就是每次吃饭睡觉补番考试评讲互黑跪烂什么的,这次就不用说了啦,先把老师要求写的东西贴出来再写点别的啦 这次暴露了很多问题,首先 ...

  9. java学习之路

    先来说一说我和it之间的不解之缘.准确来说,我接触it是从大二是我买的第一个手机开始的(国产的,展讯平台,能够运行mrp虚拟机),那时候还没有智能手机,或者说还不够普及,总之就是买不起.一次偶然的机会 ...

  10. CLOSE_WAIT TIME_WAIT

    TCP状态转移要点    TCP协议规定,对于已经建立的连接,网络双方要进行四次握手才能成功断开连接,如果缺少了其中某个步骤,将会使连接处于假死状态,连接本身占用的资源不会被释放.网络服务器程序要同时 ...