消息推送平台承接着站内对各种类型渠道的消息下发,每天承载亿级流量推送。项目主要对用户侧的召回(营销)以及通知消息触达,也同时负责对内网的告警和通知消息发送。
在真正面试的过程中,当面试官让你项目介绍的时候,你就可以这样答:
1、消息推送平台它承接着各种消息类型的推送,比如短信、邮件、小程序、微信公众号、通知栏PUSH、企业微信、钉钉等等。你可以简单理解为:只要发送消息的,就跟它脱不了关系。
2、发送的消息主要给两部分用户,一部分是我们站内的真实用户(比如我们给用户发短信验证码),另一部分是我们内网的消息(比如钉钉的工作提醒、群消息助手)
如果这时候面试官不打断你,你就继续跟面试官说:要不我来给你讲下系统的架构?
如果面试官打断了,问了别的问题,那在这就先结束了,不过,你总会遇到机会把你的项目架构跟面试官描述描述。
这个过程中,你可以拿上你的笔和纸给面试官画画,交流交流,其实就是我GitHub仓库中README
的这个图:
这个过程可以这样跟面试官描述:
1、在消息推送平台里,我们有个接入层austin-api
,它是消息的统一入口,所有的消息推送都会经过该接入层进行处理。
2、使用消息推送平台的业务方可以简单分为两种角色:运营和技术。如果是技术,他会调用我在接入层暴露的接口。如果是运营,他会使用我的消息推送后台去设置定时任务推送,所以我们会有个推送后台austin-admin
以及定时任务模块austin-cron
3、接入层干的事情比较简单,简单概括就是消息做简单的校验以及参数拼装后就写入到了消息队列
4、写到了消息队列之后,自然就有个逻辑层对消息队列的消息进行消费,在我这边叫做austin-handler
模块,它主要对消息做去重、夜间屏蔽等逻辑,最后就分到不同的消息类型Handler进行消息发送
5、消息推送平台跟普通消息下发最大的不同是我们是实现对消息全链路追踪的,业务方可以通过推送后台实时查看消息下发的情况,针对消息模板和用户都是OK的(比如这个用户是否接收到消息,如果没接收到,那可能是因为什么被过滤了)
6、所以消息推送平台会有个实时流的模块,用Flink实现的。我在消息处理的过程中对多个关键的位置进行埋点,在Flink对这些信息做清洗处理,实时的会写进Redis、离线的会落到Hive中
基于这个描述,以及你画的图,面试官一般就能有个比较简单的认知了,至少这个过程中你证明了你这系统是有设计的。有可能听到一半就会被打断问细节的,也可能会听你说完全程,但至少你要有类似这种描述。
不要上来就讲各种的实现细节,各种如何实现去重、夜间屏蔽的功能。面试官如果感兴趣,他肯定会在后面问你的,在这里先把系统的整体架构跟他聊一遍。
项目主要负责人
不要慌,别说自己负责数据库表的设计这种,如果你是新人,数据库表还轮不到你设计。austin
有完整的从零搭建文档,只要你用心研究了,就应该写项目负责人。
如果你只看了几天,并且你认为你几天就能完全搞懂,那我还是劝你不要把austin写在你的项目上。
SpringBoot、Flink、Redis、Apollo等
这里把自己熟悉的技术栈拎出来讲讲,不熟悉的就隐藏起来(比如Spring Data JPA
,你就用过,只知道它的底层实现是Hibernate,那就不要在这里了)。但如果你对Mybatis
又很了解,你就可以把Mybatis
加上(反正面试官又看不到代码,你说Mybatis
那就是Mybatis
,OK?)
注意的是:这里写的技术栈,自己是要有点墨水的(很容易就被问到),为什么使用XXX而不使用XXX啊?当时是怎么考量的。
1、全类型渠道消息的生命周期链路追踪:在每个关键处理的阶段上进行埋点,将点位收集到Kafka,Flink统一清洗处理。实时数据写入Redis,离线数据写入Hive,固化出实时和离线的统一推送基础模型
2、消息资源隔离:不同的渠道不同的消息类型互不影响并且利用动态线程池可配置化地对消费能力进行调控
3、拥有完备的消息管理平台基础建设:对系统和应用资源有完整的监控和告警体系、消息模板工单审核、各种消息模板的素材管理等等
作为一个平台,我理解下应该关注的是着可用性、可扩展性以及平台能力。
这里写出的项目亮点可能后续还会增改,但这以上几点我感觉都是可以拉出来跟面试官聊聊这其中的实现过程的(特别是第一点和第二点)
在简历上我建议不要写太多技术上的细节,这个系统核心功能简单可能面试官能get到,但如果是业务系统,面试官就不知道你在写什么了。如果面试官感兴趣,是会问你技术细节的,到时候再好好吹就行啦。
项目描述:消息推送平台承接着站内对各种类型渠道的消息下发,每天承载亿级流量推送。项目主要对用户侧的召回(营销)以及通知消息触达,也同时负责对内网的告警和通知消息发送。
项目角色:项目主要负责人
项目技术栈:SpringBoot、Flink、Redis、Apollo等
系统设计亮点: