即时通讯是目前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. 用Mockito测试SpringMVC+Hibernate

    用Mockito测试SpringMVC+Hibernate 译自:Spring 4 MVC+Hibernate 4+MySQL+Maven integration + Testing example ...

  2. linux - tar命令简单使用

    tar 新建一个tar文档 touch file1 touch file2 mkdir dir1 touch dir1/file3 # 普通tar文档 tar -cf tar-file.tar fil ...

  3. jQuery 学习总结(上)

    第二章:基础选择器 第三章:过滤性选择器 第四章:表单选择器 第五章:jQuery  操作DOM 第六章:jQuery 事件与应用 第七章:jQuery 实现ajax应用

  4. esri-leaflet部分瓦片缺失问题及解决办法

    esri-leaflet加载TileLayer的时候,有时候由于数据的原因,造成部分瓦片缺失的问题,网页加载TileLayer的时候,当地图范围正好拖动到缺失的范围的时候,会一直请求 http://d ...

  5. ubuntu通过虚拟域名访问不了 502 / 网络错误

    ##之前把虚拟机的lamp环境搭建好,但是通过自己windows在浏览器访问一直不能正常运行. 简单说明一下我的相关设置: 1.设置windows的ip映射 C:\Windows\System32\d ...

  6. CSS3 3D的总结(初学者易懂)

    CSS3 3D案例的总结 如果要说是3D的基础概念,首先我就来说一说rotateX().rotateY().rotateZ()这几个属性 rotateX():对应的是3D模型中的X轴上的旋转,传入的参 ...

  7. Xamarin组件包 Xamarin.ToolKit第二波

    Xamarin.ToolKit第二波 一 圆角按钮 xamarin.froms提供的标准button按钮设置了圆角和边框,都没有明显圆角样式,于是乎自己重写了渲染类.道理吧就是重写ButtonRend ...

  8. 在Windows Server2016里通过Hyper-V安装Liunx Container

    Windows Server2016正式发布已经有一段时间了.无可厚非,原生Docker的支持是这个版本一个非常大的亮点. Windows Container 的安装在网上有很多教程,我这里不过多的描 ...

  9. git的安装和环境配置过程(学习笔记)

    1.安装git 官网下载:https://github.com(目前官网好像找不到了,但是妙味的视频里面是在官网下载的)https://git-for-windows.github.io/ (廖雪峰老 ...

  10. 编程思想之——"人是活的,程序是死的"

    "人是活的,程序是死的"这句话我时常提起,可能很多人不是很理解我为什么会这样说,下面我就简单来谈谈我对这句话的理解. 1.不要因为技术而技术,技术选型的初衷是需求. 现在很多人在做 ...