评论

收藏

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

编程语言 编程语言 发布于:2021-08-17 12:07 | 阅读数:328 | 评论:0

如何实现广告弹窗触达频率的控制?
今天我们聊聊实际工作中遇到的一个问题:
产品提出想在我们的产品的首页做个弹窗广告,但是又不希望用户每次进来都给用户弹窗,每个用户每天进来只弹一次就好了。
这个如何实现?
方法一(暴力破解)
或许有些人会觉得这个挺简单的,这个问题抽象出来不就是要记录用户的行为么,这个将用户的每一次行为都存在redis或数据库中,每次访问的时候都查一下数据库或redis判断一下,有没有。
以redis举例, 如果用户今天访问过一次,就在redis里面设置一个以用户为维度的key。
DSC0000.jpg

真爽,这么简单,然后我们就高高兴兴的玩去了,突然某一天,运维找到你,告诉你redis服务被挤爆了,内存不足。什么鬼?你抬起脑袋,暗暗一想,你们的用户有1个亿用户。
打算一个用户占用14个字节,14b*100000000/1024/1024=1335mb,我去,这么一个小功能,都占用至少1g的内存了。
方法二(bitmap数据结构)
为了实现这样的小的效果,花费了1g的宝贵的redis内存空间,显然是划不来的。有没有一种办法或数据结构可以即实现想要达到的一天一次弹窗效果,又能占用内存最小。
这个时候,你突然想到用户的唯一标识符(uid),是一个从0到1个亿递增的整数。一天一次弹窗对应一个01二进制值。那能否分配一个大的数组,数组的值是boolean值,这个时候你突然想到了redis的bitmap数据结构。
DSC0001.jpg

抬起头算了算,一个用户uid为1bit位,1亿用户,大概:100000000b/8/1024/1024=11mb。到这里,需要1个g的内存的功能现在只需要11mb就能存储下来。
方法三(布隆过滤器)
以为到使用bitmap解决问题就完了么?如果现在不止有一个弹层呢,比如1000个?亦或者用户的唯一标识符并不是一个自增的整数。这个时候如何处理呢?
如果我们愿意牺牲少了的准确度,达到比较大的存储量的话,你可能会考虑到布隆过滤器(bloom filter)。
DSC0002.jpg

在方案二中的分配一大片的bitmap基础上,将要保存的uid或key通过若干个哈希函数映射到不同的bit上保存。
这种方案有个好处就几十mb内存可以存储几十亿的数据去重判断。当然坏处就是会牺牲掉少量的准确性。
方案四(前端存储)
在上面三种方案的基础上,我们会发现想这些控制内存的方法,我们想得老细胞都要死掉好多。有没有一种简单有效的方式呢?
如果产品不需要强制要求必须用户一天只弹一次,那能不能将这个控制任务交给前端来控制呢,比如存储在cookie或locolstorage中?,这样就完全不用担心存储内存的问题了。
但是这样有个缺点就是如果用户在不同的客户端(h5或app)中打开,会出现一天弹多次的情况,控制可能没那么精准。
没有完美的技术方案,只有最合适的技术方案。
到这里,如何控制频率的方法介绍完毕。希望对你有所帮助。
以上所述是小编给大家介绍的如何实现广告弹窗触达频率的控制详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对CodeAE代码之家网站的支持!
原文链接:https://juejin.im/post/5cabed58f265da036b4a3f8f

关注下面的标签,发现更多相似文章