优惠券群发方案设计

1. 功能描述

营销管理:需要通过圈人相关功能,对特定的群体进行优惠券发送并信息推送到位,并且统计后期触发率。

1.1 活动列表

活动推送

1.2 新增活动

新增活动

1.3 活动详情

活动详情

2.设计方案

技术选型有多线程和MQ俩种机制来实现,MQ业务解耦的情况更符合我们的实际需求,所以选在rabbitmq来实现具体的生产消费。

2.1 架构图

总体设计流程图

MQ选型设计图

2.2 设计介绍

  1. 活动执行顺序
    活动的提交是串行执行,所以多个活动本身已处于一个FIFO队列。对于已经提交执行的活动,我们通过定时任务扫描待执行活动来进行触发,对于排队中的活动信息,都存入redis库,减少定时任务扫描mysql造成的压力。
  2. 标签覆盖
    通过标签所覆盖的人群基础进行筛选,针对自动推送渠道,提前预处理每个人最优推送渠道,保证高质量的信息触达。
  3. 队列拆分
    如果针对单人的优惠券发放和信息通知同时处理,那么其效率将降低。所以我们将单个人的推送情况拆分为发券队列消息推送队列,俩个队列(并行或串行)根据业务需要,都能极大的提高推送效率。
  4. work queue
    消费者要提高消费能力,就需要使用到消费者的多线程配置和批量消费能力。rabbitmq现有功能,无需额外开发工作。
  5. 推送记录
    推送记录属于不可更改数据,存储的选型方式很多:mongodb等。但是我们也可以使用mysql月报表模式来进行存储,这样的分表模式也会提高查询效率。
  6. 活动结束标示
    在拆分任务进发券队列消息推送队列两个队列之后,均会向当前俩队列插入一个(n个)(防丢失情况)的最低权重的结束标示的信息,正常情况下,消费者在收到当前标示信息时会主动判定当前队列任务已执行完毕并可以通知修改当前活动结果状态。但是消费端属于多线程执行,会出现当前消息被提前消费,而并存几个处于处理中的消息,所以此处会主动查询rabbitmq是否存在剩余unacked信息,如果存在(除去自身),则将当前的结束标示信息重归队列,等待后续消费,一直确保其他消息被消费完毕。
  7. 活动终止
    前端提交活动终止时,我们主要通过控制消费队列来进行中断,通过清除rabbitmq中发券队列消息推送队列俩个队列中尚未被消费的信息,原有正在处理的信息不受影响。同时,变更当前终止活动的状态。

3. 总结

总体思考下,当前模块功能的核心设计理念是:解耦预处理
解耦:充分利用好中间件,系统层面可以减少系统与系统简单同步操作,业务层面可以让多个业务逻辑同时进行。
预处理:硬件配置和节点固定的情况下,充分做好数据的预处理,可以极大加快消费端的能力。处理事情的效率很大程度上是消费端没有优化好。

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

推荐阅读更多精彩内容