使用optimizely做A/B测试
摘要:
optimizaly是一个提供A/B测试服务的网站,可以可视化地在线编辑测试内容和目标,简单方便。
1. A/B测试简介
所谓 A/B 测试,简单来说,就是为同一个目标制定两个方案(比如两个页面),让一部分用户使用 A 方案,另一部分用户使用 B 方案,记录下用户的使用情况,看哪个方案更符合设计目标。参考:
http://oldj.net/article/ab-testing-basic-concept
http://www.zhihu.com/question/20045543
http://en.wikipedia.org/wiki/A/B_testing
https://www.optimizely.com/ab-testing
2. optimizaly是什么
optimizaly是一个提供A/B测试SaaS服务的互联网公司,网址是https://www.optimizely.com。是家美国公司,2010年创立,获得$1.2M,2013.04获得A轮$28M,2014.05获得B轮$57M。参考:
https://www.optimizely.com/about
http://en.wikipedia.org/wiki/Optimizely
http://www.zhihu.com/question/23756936
3. optimizaly的使用简述
(1)测试发布
测试发布流程:登陆optimizaly的网站 —>输入要测试的URL —>在optimizaly上编辑对照版本的页面 —>在optimizaly设定测试目标 —>在页面源码上加入一小段js,该js由optimizaly生成 —>启动测试
所有测试发布操作都是可视化的。可以在线编辑页面各元素的内容、坐标、样式,也可以插入或删除元素。新增图片时,可以上传到optimizaly的cdn上,也可以提供已存在图片的URL。
提供了多种测试目标的设定:
a)点击事件,在一个预览页面上,可视化地进行点击页面配置
b)pageView,提供精确、简单、子串、正则表达式四种URL匹配方法
c)自定义事件,要通过optimizaly提供的api进行设定
操作细节详见:https://www.optimizely.com/gettingstarted
测试发布的关键在于optimizaly生成的js代码,所有与测试相关的在线编辑,都会相应地体现在该js代码里,最终也是通过此js控制页面显示与数据统计。

注意:该js需要加入到html的head中。该js保存在optimizaly的cdn服务器上,每个测试有一个固定的js的url,但每次修改测试内容或目标,都会生成一个新的js,但url不变。
实际的页面大改版,不适合在线编辑页面,会有实际的页面文件存在于我们自己的服务器,可以通过重定向的方式,对新旧版本页面做A/B测试,详见:https://help.optimizely.com/hc/en-us/articles/200040675-Redirect-experiments-Comparing-two-separate-pages
(2)页面浏览与统计
页面浏览流程:输入网址并回车 —>下载页面元素,并要下载optimizaly的js —>optimizaly的js通过hash计算出展示给用户的页面版本,并通过js控制展示,发送一个uv记录到optimizaly服务器—>用户操作... —>如果触发预设的事件,则通过ajax发送相应记录到optimizaly服务器
用户浏览测试页面,会额外产生两类流量:
a)下载optimizaly的js代码:因为js是在head中,所以打开页面时必然要先加载此js,且会影响到用户打开页面的速度。js文件大小是46KB,位于美国的服务器上,我的网络的打开速度在200-500ms之间。可以考虑把此js放到自己的国内服务器上,但要保证每次修改测试时,都要及时更新js文件。
b)触发统计事件,发送消息给optimizaly服务器:接受操作日志的服务器也在美国,我的网络延迟在300ms以上,低概率出现发送失败或时间超长的情况,但因为是异步发送操作日志,对用户是没有影响的。如果发送失败,则丢失统计数据

(3)统计结果查看
optimizaly有专门的测试结果页面,使用比较简单,结果也直观。有几个指标,说明如下:
• visitor over time:统计周期的uv数
• conversion over time:如果用户对页面进行操作,此处数值就加1;多次操作也算1
• conversion rate:conversion/visitor的计算结果
• improvement:会挑选一个版本叫做baseline,此数值表示与baseline的转换率差值
• chance to beat baseline: 若用当前版本替换baseline,战胜它的概率
4. optimizaly的一些技术细节
(1) 如何辨别UV
关键在于cookie,会存储用户id,测试id,浏览版本记录,用户设备信息,最近10次历史操作,时间戳等信息。详见:
https://help.optimizely.com/hc/en-us/articles/200040335-How-Optimizely-Works-Snippet-order-of-operations-JavaScript-evaluation-timing-and-cookies
optimizaly生成的js中,根据用户cookies,通过一个hash算法,计算出当前用户展示的页面样式,或者跳转页面,一个用户总会看到相同版本的页面,算法的细节没能找到资料。如果删除了cookie,即便是同一台电脑同一个浏览器,再次访问时,又会当做一个新的uv。
(2) optimizaly的架构
有三个组件:
a) Google App Engine,用于存储用户账户、测试配置信息
b) Amazon Elastic Compute Cloud and Simple Storage Service,用于接收、存储、计算统计数据
c) Akamai ,用于存储生成的js文件

optimizaly的官方网站没有披露更多技术细节
5. optimizaly的坑
(1)费用
它提供的A/B测试是收费的,按照被测网站的uv收费,类似运营商套餐,按月计费,不同套餐提供不同的月uv上限,超出部分费用另算。详见:https://www.optimizely.com/pricing
(2)统计精度
可能出现统计不准的情况,可能的原因有
a)统计事件发送失败:统计服务器在美国,低概率发送失败,文档前面有描述
b)统计结果非实时:一次用户操作后,一般5分钟以后才能在统计结果里查到,并且各指标是分开统计的,例如可能用户的uv数已经+1了,但该用户的点击操作还没有+1
c)可能optimizaly本身就不准
(3)optimizaly网站最好翻XX墙
测试配置、统计结果等页面经常打不开,最好带梯子。
使用optimizely做A/B测试的更多相关文章
- nodejs做的一个测试端口程序
最近在学习nodejs的http,然后做了一个测试域名有没有使用那些端口,原意是用来做一个本地的静态服务器,然后运行前先测试端口,首先要用到的是net模块,主要用到的是Socket,判断其连接状态即可 ...
- Apache JMeter 做接口并发测试
获知来源:查找如何使用Postman进行接口并发测试时,在StackOverflow上看到,说postman只能做串行测试,而且postman并不是被设计做这种测试的:而jmeter就是为了测试而开发 ...
- nginx整合tomcat集群并做session共享----测试案例
最近出于好奇心,研究了一下tomcat集群配置,并整合nginx,实现负载均衡,session共享,写篇记录,防止遗忘.---------菜鸡的自我修炼. 说明:博主采用一个web项目同时部署到两台t ...
- ab命令做压测测试
1. 背景:互联网发达的今天,大大小小的网站如雨后春笋,不断出现,但是想要做出一个网站很简单,但是想要做好一个网站,非常非常难,首先:网站做好之后的功能怎么样这都是次要的,主要的是你的网站能承受怎么样 ...
- 【转】Jmeter做web压力测试时设置持续时间注意点
头一回使用jmeter做web的压力测试,遇到个很莫名其妙的问题,不管我的线程组怎么设置,它就是执行一次就结束了. 设置循环次数为300,不使用调度器--〉执行一次就结束了,循环次数未生效 设置循环次 ...
- 初始化一台linux server来做项目管理和测试
毕业以后很多没做过这么技术的事情了,不过今年要开始咯. Goal: 练手安装Nginx,并且配置不同的server,后端有Tomcat的(JIRA),有PHP(总得有的),还有Tornado和Node ...
- 用nc做网络压力测试
测试结果: 1.数据的收发正常,没有出现丢包: 2.平均数据接发速率为:112MB/S,基本用完的千兆带宽. 测试方法: 1.通过FTP拷贝3.6G ...
- 使用gtest自动化测试并给出性能测试结果(windows 版本,版本平台也可以使用,但并没有做完整的测试)
/************************************************************* *使用gtest自动化测试 * ********************* ...
- CentOS上使用sysstat做系统监控测试
先安装sysstat yum -y install systat 然后,再改一下任务计划 [root@localhost sa]# cat /etc/cron.d/sysstat # Run syst ...
随机推荐
- [Leetcode][Python]54: Spiral Matrix
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 54: Spiral Matrixhttps://leetcode.com/p ...
- 数据挖掘之分类算法---knn算法(有matlab例子)
knn算法(k-Nearest Neighbor algorithm).是一种经典的分类算法.注意,不是聚类算法.所以这种分类算法 必然包括了训练过程. 然而和一般性的分类算法不同,knn算法是一种懒 ...
- hdu 1757 A Simple Math Problem(矩阵快速幂乘法)
Problem Description Lele now is thinking about a simple function f(x). If x < f(x) = x. If x > ...
- java整合easyui进行的增删改操作
首先发一下效果图 显示全部用户信息 加入用户信息 删除用户信息 编辑用户信息 以下就来介绍一下easyui的crud,在java中是怎么与后台进行交换的 前台html页面,我将它命名为crud1.ht ...
- URAL 2025. Line Fighting (math)
2025. Line Fighting Time limit: 1.0 second Memory limit: 64 MB Boxing, karate, sambo- The audience i ...
- Apple Swift学习资料汇总
今年的苹果开发者大会(WWDC)上,公布了ios8的几个新特性,其中包括引入了群聊功能,支持第三方输入法等功能.但更让开发者感兴趣的莫过于Swift语言的发布了. Swift是apple自创的一门转为 ...
- jmx使用应该注意的基本规范
1.标准MBean 名称必需是在要监控的类名后面加上“MBean ”. 2.监控的类和MBean 接口必需在同一包下,也可以理解为注册的接口名字必须以MBean结尾,接口实现类比接口名字少了MBean ...
- jsoup 解析html 页面数据
我html 页面元素: /html/body/table[2]/tbody/tr[1]/td/table/tbody/tr[1]/td[2]/font/html/body/table[2]/tbody ...
- <转>Java的一些历史
Java是一种固执己见的语言,它具有很好的可读性,初级程序员很容易上手,具有长期稳定性和可支持性.但这些设计决定也付出了一定的代价:冗长的代码,类型系统与其它语言相比显得缺乏弹性. 然而,Java ...
- strcpy, mencpy, memmove三者区别
首先来看strcpy,目的是实现字符串的复制,这里需要注意几个点: 1.判断指针的有效性 2.将复制后的指针地址返回,为了支持链式操作 3.不要忘记将字符串最后一个自负'\0'复制给dest 4.注意 ...