老王的心路历程:那个做了五年的产品经理(二)

在上一篇文章中,和大家聊到了建立Web应用体验监控体系,经过了概念阶段,也完成了技术选型,就进入了把实质性的产品研发阶段。作为产品经理,时刻不敢忘记我们的产品目标:无限感知你的用户,建立完备的体验监控体系,驱动产品的设计、开发和运维!

一、一切皆操作

仔细分析终端用户和Web应用及网站的交互过程,无论是打开页面、点击链接或按钮,还是填写表单、提交查询,一切皆可归结为一个个基本的操作,由这些操作构成一次次访问(即会话),而会话最终都可以映射到具体的用户,因此我们可以用一张图来表达:

因此,在我们的产品概念中,我们不再把页面的PV当作重点,而是把所有的行为抽象为操作,比如页面被打开多少次就称为页面的操作数,按钮被点击了多少次也被称为按钮的操作数。这是一个非常重要的概念,因为优云Web中大多数指标皆是围绕操作来进行聚合的。举例来说,我们可以知道某个时间段内使用某种浏览器的用户,登录按钮被点击的次数、响应时间(网络、服务端、客户端)、满意度(满意、可容忍、不可接受)等关键指标。

这里值得提一下操作类型,我们把操作分成了四种基本的类型:重定向、链接、AJAX、表单提交,重定向即打开某个URL装载页面或手动刷新某个页面,链接即点击某个链接跳转到某个URL,AJAX即发起某个XmlHTTPRequest交互局部更新页面(现在的Web应用中基本都有用到此技术,与操作无关的纯XHR请求不会被记录成操作),表单提交很好理解,填写表单并提交或者发起一个查询都属于这种操作类型。

目前我们只记录了与服务端有交互的操作,而对纯客户端的操作暂未记录。

二、尽可能全量采集数据

之前我们提到了对我们有价值的数据有用户的操作行为数据以及操作行为的上下文数据,我们可以在页面中嵌入一小段JS代理,当用户与页面产生交互时,代码片段会自动执行收集数据并定期上报到服务端分析。每一次用户的交互行为其实讲了一个故事:

·      谁

·      什么时间

·      在哪个页面

·      操作的内容是什么

·      操作的类型是什么

·      使用的浏览器元数据有哪些

·      浏览器加载的过程数据有哪些

·      是否出错

有了这些数据,接下来就交给云端的服务器去做了,对每一个操作进行聚合分析,通过指标体系去度量这个操作的体验情况。当然,上层业务还是需要做不少的事情,比如如何区分一个会话,如何识别一个独立用户和账号,如何对一组页面进行聚合分析,如何统计一个跨页面功能按钮的操作数,如何解决多域名指向同一站点的问题等等。下图是对一个操作进行体验分析:

三、无码埋点让分析更敏捷

先解释下无码埋点,这里说的无码并非不要嵌入js代码,与无码埋点对应的是代码埋点。从部署js代理开始,系统自动全量采集了界面中被用户操作的元素数据,后面其实我们要做的就很简单了,把需要的数据拿出来看即可。具体去“拿”的过程还是省不了的,我们是这么考虑的:

1、你不需要关注界面上所有的元素

2、跨页面元素的跟踪或页面组定义还是需要人来定规则

3、自动化的命名方式不友好不是你要想的

听上去很酷,对不对?是不是小白PM都可以用得起来,从此不再需要开发人员干埋点的脏活累活了,而对产品经理来说,不要整理埋点的清单了,不要求着研发人员解释埋点的逻辑,想拿数据就拿数据,进退自如效率大大提高。无码埋点的好处是无须等待即可看到历史数据,但如果涉及到对历史数据进行重新标记命名,如果历史数据较多肯定需要耗费较长时间。

当然了,无码埋点也不是没有缺点的,但我们要的是最小化代价获取有价值的隐藏在大数据背后的知识,虽有缺陷却不影响我们做合理的决策。我们后面会谈到各种埋点的技术方案的利弊分析。

四、多维分析洞悉细微之处

对好的体验监控产品来说,多维分析是共性的需求,所谓细微之处见真章,产品的创意和问题往往从细微之处可以觉察到。维度可以是时间,也可以来自于采集的客户端浏览器的元数据信息,也可以是地理、运营商,甚至可以是自定义的维度。各类产品其实说得挺多了,这里不再赘述。

五、扩展API让数据更有价值

适当的API能力可以让数据发挥更大的价值,基于这些数据可以让分析和问题定位更加给力。

1、接入真实用户:默认情况下,我们采用js生成的id来标识用户,不能很好地标识真正的用户,无法把访客与真实的人建立起联系。如果有用户登录行为的话,可以用YYRUM.identify(user_id)来标识,这样就能标识发生事件的真实用户。建议在用户登录后,立即调用这个方法。

接入真实用户还提供 API 设置用户的属性,并支持以用户属性为维度进行数据分析。你可以首先使用上面的 identify(user_id)来标识用户。然后可以对这个特定的用户设置一些属性,比如这个人的性别,年龄,等等。

2、接入错误:虽然我们尽可能的采集用户端的错误信息,但事实上浏览器抛出的错误对我们解决问题的能力是非常有限的。在收集到的数据中常常会有很多的script error.错误,而错误的堆栈确看不到任何信息。原来是浏览器的同源性策略(CORS),浏览器会把不同域的js报错信息替换成script error,并且其他字段也置为空,这个时候就很难收集的真正有效的信息。(PS:针对上面的解决方案:请求的js返回头上加上```Access-Control-Allow-Origin```,并设置可信的来源,在引用js的标签上加上 ```crossorigin```属性)

这样依然不够,我们可以采用主动上报错误的方式,把一些自定义的错误信息上报到云端进行聚合分析。举例如下:

YYRUM.report(ex,{

msg: ‘自定义错误’,

line: 89,

col: 90,

func: a

}) ```


六、技术的不完美性

事实上,前面说了各种方案都有其优劣点的,而JS代理方式本身有一些局限性,简单分析如下:

1、采用js数据收集原理决定了:数据能否收集以及收集后的数据是不是你想要的,根本依赖于JavaScript标记代码是否能正确执行;这也意味着如果在数据收集环节走入误区,将给随之而来的分析工作带来不可修复的影响(访问者不会因为你犯下的数据收集错误而帮你再现历史访问过程)。

2、我们的方案固然能降低工作量,把很多工作交给云端去做,但随之而来的是抓取的信息越多,也就意味着浪费的流量也越多,存储和索引的成本也越高。

3、对部署也有一定的要求,一个是要求覆盖面,是否覆盖了所有要分析的页面;另外一个是如果用户浏览器版本过低,有些指标获取不到。

以上是我个人的总结,Web体验监控产品的六大基本内容,欢迎大家一起交流(作者微信:uyunsoft)。后续再与大家聊聊埋点的那些事。

优云敏捷运维www.uyun.cn

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267

推荐阅读更多精彩内容