最近我学到的ABTest知识

简介: 那什么是ABTest呢?这篇文章带你们入门一下。

一、ABTest的介绍


比如我写了一篇关于ABTest的文章,我希望这篇文章的阅读量能上2500,但是我没想好标题叫什么比较合适。一条推文的标题非常能影响到阅读量,于是我想了几个的标题:

  • 最近我学到的AbTest知识
  • AbTest入门

而我不知道哪个标题效果会更好一些,于是我做了这么一个尝试:

  1. 《最近我学到的AbTest知识》这个标题推送给10%的用户
  2. 《AbTest入门》这个标题推送给10%的用户
  3. 过一段时间后,我看一下效果,哪个标题的阅读量更高,我就将效果高的标题推送给剩余80%的用户

30.png

要注意的是:在推送的文章的时候,除了标题不同,其他因素都需要相同(不能被别的因素给干扰),这样看数据的时候才有说服力。


1.1为什么要做ABTest?


做ABTest的原因其实很简单,我们在做业务的时候会有各种各样的想法,比如说:

  • “我觉得在文案上加入emoji表情,这个推送的消息的点击率肯定高”
  • “我觉得这个按钮/图片换成别的颜色,转化率肯定会提高”
  • “我觉得首页就应该设计成这样,还有图墙应该是这样这样..“
  • …..

但是,并不是所有的想法都是正确的,很可能因为你的想法把首页的样式改掉,用户不喜欢,就影响到了GMV等等等….

一个好的产品都是迭代出来的,而我们很可能不清楚这次的迭代最终是好是坏(至少我们是觉得迭代对用户是好的,是有帮助的,对公司的转化也是好的),但是我们的用户未必就买账。

于是,为了降低试错成本,我们就做ABTest。一个功能做出来,我们只放小流量看下效果,如果效果比原来的功能差,那很可能我们这个想法没有达到预期。如果小流量效果比预期要好,再逐步加大流量,直至全量。


二、怎么做ABTest?


从上面的案例,其实我们大概知道,ABTest最主要做的就是一个分流的事

  • 将10%流量分给用户群体A
  • 将10%流量分给用户群体A

31.png

我们需要保证的是:一个用户再次请求进来,用户看到的结果是一样的

比如说,我访问了Java3y,他的简介是:“一个坚持原创的Java技术公众号“。而一个小时后,我再访问了他一次,他的简介是:“一个干货满满的技术号“。而一个小时过后,我又访问了他一次,他的简介是:“一个坚持原创的Java技术公众号“。

32.png

这是不合理的,理应上用户在一段时间内,看到的内容是相同的,不然就给用户带来一种错乱感。

OK,于是一般可以这样做:

  • 对用户ID(设备ID/CookieId/userId/openId)取hash值,每次Hash的结果都是相同的。
  • 直接取用户ID的某一位

现在看起来,ABTest好像就是一个分流的东西,只是取了个高大尚的名字叫做ABTest。


2.1 ABTest更多的内容


假如我做了一个UI层面上的ABTest,占用全站的流量80%,现在我还想做搜索结果的ABTest怎么办?只能用剩下的20%了?那我的流量不够用啊(我可能要做各种实验的呢)。UI层面上的ABTest和搜索结果的ABTest能不能同时进行啊?

答案是可以的。因为UI层面和搜索结果(算法优化)的业务关联性是很低的。如果要做“同一份流量同时做UI层面上和搜索结果的ABTest”,那要保证“在UI层面做的ABTest不能影响到搜索结果的ABTest

  • 业界应用最多的,是可重叠分层分桶方法
  • 层与层之间的流量互不干扰,这就是很多文章所讲的正交(流量在每一层都会被重新打散)

33.jpg来源:https://www.infoq.cn/article/BuP18dsaPyAg-hflDxPf

我们就可以这样干:通过 Hash(userId, LayerId) % 1000类似的办法来实现

  • 每一层的实验不管有多少个,对其他层的影响都是均匀的

我的理解:

为了实现UI/算法/广告 这些业务上没什么关联的,能够使用同一份流量做ABTest测试,所以分了层。流量经过每一层都需要将流量重新打散(正交)----每层实验后,不会影响到下一层的实验


如果业务关联强的应该放在同一层,同一层多个实验是互斥的(比如 一个按钮颜色改为绿色作为一个实验,一个按钮的样式改成大拇指作为一个实验。这两个实验的流量是要互斥的(不然你咋知道用户是因为你的按钮颜色还是样式而点击)

34.png


最后


一个完整的ABTest系统,不单单只做分流,还会给用户(我们程序员)提供一个方便可配置的后台系统,做完实验提供数据报表展示等等等~

目录
相关文章
|
运维 搜索推荐 数据安全/隐私保护
什么是C端 什么是B端 这里告诉你
C端产品早已将运营专业化,并细化到各维度的运营了,比如运营的工种可以细分为“活动运营岗、用户运营岗、增长裂变岗、内容运营岗”等等。
什么是C端 什么是B端 这里告诉你
|
4月前
|
小程序 编译器 数据安全/隐私保护
小白保姆级教程:微信公众号开发,从0到1
【8月更文挑战第8天】小白保姆级教程:微信公众号开发,从0到1
357 3
小白保姆级教程:微信公众号开发,从0到1
|
7月前
|
监控 安全 Cloud Native
云计算架构设计与实施:构建高效、可扩展的云解决方案
【4月更文挑战第30天】本文探讨了云计算架构的关键要素,包括服务模型(IaaS, PaaS, SaaS)、部署模型(公有云、私有云、混合云)及可扩展性、安全性、可靠性和成本效益。实施策略涉及需求分析、选择云服务商、设计基础设施、自动化、监控和灾备计划。最佳实践推荐模块化设计、微服务、DevOps、CI/CD、多租户支持和云原生应用,以确保高效、安全且成本优化的云环境。
|
7月前
智能化办公,尽在免费OA办公系统
利用免费OA办公系统,可以实现从传统办公方式到智能化办公方式的转变,为企业提供高效、智能、便捷的办公环境。
98 3
|
7月前
|
存储 编译器 Go
go语言制作简单图书管理系统
go语言制作简单图书管理系统
109 0
|
缓存 前端开发 PHP
PHP - Laravel The stream or file “/storage/logs/.“ could not be opened in append
PHP - Laravel The stream or file “/storage/logs/.“ could not be opened in append
521 0
|
缓存 Java Linux
Spring Cloud【Finchley】-13 Eureka Server HA高可用 2个/3个节点的搭建及服务注册调用
Spring Cloud【Finchley】-13 Eureka Server HA高可用 2个/3个节点的搭建及服务注册调用
135 0
Spring Cloud【Finchley】-13 Eureka Server HA高可用 2个/3个节点的搭建及服务注册调用
|
jenkins 持续交付 开发工具
jenkins无法连接仓库:Command “/usr/bin/git ls-remote -h -- https://gitee.com/xxx.git HEAD“ returned
jenkins无法连接仓库:Command “/usr/bin/git ls-remote -h -- https://gitee.com/xxx.git HEAD“ returned
1211 1
jenkins无法连接仓库:Command “/usr/bin/git ls-remote -h -- https://gitee.com/xxx.git HEAD“ returned
|
存储 搜索推荐 数据可视化