博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何实现广告弹窗触达频率的控制?
阅读量:5992 次
发布时间:2019-06-20

本文共 1268 字,大约阅读时间需要 4 分钟。

如何实现广告弹窗触达频率的控制?

今天我们聊聊实际工作中遇到的一个问题:

产品提出想在我们的产品的首页做个弹窗广告,但是又不希望用户每次进来都给用户弹窗,每个用户每天进来只弹一次就好了

这个如何实现?

方法一(暴力破解)

或许有些人会觉得这个挺简单的,这个问题抽象出来不就是要记录用户的行为么,这个将用户的每一次行为都存在redis或数据库中,每次访问的时候都查一下数据库或redis判断一下,有没有。

以redis举例, 如果用户今天访问过一次,就在Redis里面设置一个以用户为维度的key。

真爽,这么简单,然后我们就高高兴兴的玩去了,突然某一天,运维找到你,告诉你Redis服务被挤爆了,内存不足。什么鬼?你抬起脑袋,暗暗一想,你们的用户有1个亿用户

打算一个用户占用14个字节,14B*100000000/1024/1024=1335MB,我去,这么一个小功能,都占用至少1G的内存了。

方法二(Bitmap数据结构)

为了实现这样的小的效果,花费了1G的宝贵的Redis内存空间,显然是划不来的。有没有一种办法或数据结构可以即实现想要达到的一天一次弹窗效果,又能占用内存最小

这个时候,你突然想到用户的唯一标识符(uid),是一个从0到1个亿递增的整数。一天一次弹窗对应一个01二进制值。那能否分配一个大的数组,数组的值是boolean值,这个时候你突然想到了Redis的Bitmap数据结构。

抬起头算了算,一个用户uid为1bit位,1亿用户,大概:100000000b/8/1024/1024=11MB。到这里,需要1个G的内存的功能现在只需要11MB就能存储下来。

方法三(布隆过滤器)

以为到使用bitmap解决问题就完了么?如果现在不止有一个弹层呢,比如1000个?亦或者用户的唯一标识符并不是一个自增的整数。这个时候如何处理呢?

如果我们愿意牺牲少了的准确度,达到比较大的存储量的话,你可能会考虑到布隆过滤器(Bloom Filter)。

在方案二中的分配一大片的bitmap基础上,将要保存的uid或key通过若干个哈希函数映射到不同的bit上保存。

这种方案有个好处就几十MB内存可以存储几十亿的数据去重判断。当然坏处就是会牺牲掉少量的准确性。

方案四(前端存储)

在上面三种方案的基础上,我们会发现想这些控制内存的方法,我们想得老细胞都要死掉好多。有没有一种简单有效的方式呢?

如果产品不需要强制要求必须用户一天只弹一次,那能不能将这个控制任务交给前端来控制呢,比如存储在cookie或locolstorage中?,这样就完全不用担心存储内存的问题了。

但是这样有个缺点就是如果用户在不同的客户端(H5或APP)中打开,会出现一天弹多次的情况,控制可能没那么精准。

没有完美的技术方案,只有最合适的技术方案。

到这里,如何控制频率的方法介绍完毕。希望对你有所帮助。

都看到这里了,关注个公众号吧

转载于:https://juejin.im/post/5cabed58f265da036b4a3f8f

你可能感兴趣的文章
Windows Server 2016 中英文版下载!
查看>>
***同时上网(批处理,自动获取IP地址并更改路由)
查看>>
SQLite 3.7.13的加密解密(六)—— 使用方法
查看>>
利用nginx_upstream_check模块检查nginx代理后端存活
查看>>
普通用户在rhel5和rhel6版本下执行ifconfig区别
查看>>
SQL Server 审核(Audit)-- 介绍
查看>>
SQL Server 2016:内存列存储索引
查看>>
立项申请书模板
查看>>
C#提高知识 ADO.NET实体数据模型(1)
查看>>
送给那些搞电脑维修的人儿
查看>>
linux基础概念和个人笔记总结(3)
查看>>
如何重置3850交换机密码
查看>>
Exchange Server 2013预览版服务器角色概况
查看>>
IPSec ***和SSL ***两种***的安全风险比较
查看>>
智能设备:用户隐私丛林,恶意应用淘金地
查看>>
Hadoop入门扫盲:hadoop发行版介绍与选择
查看>>
实战1:创建Windows Server 2008域
查看>>
Gartner:实现高水平云安全还任重道远
查看>>
轻松搞定Spark安装
查看>>
在 Windows 2012 R2 安装 SharePoint 2013
查看>>