某电商基于阿里云Flink的实时风控实践

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
简介: 客户成功基于阿里云实时计算 Flink 版的企业级CEP能力落地实时风控解决方案,更近一步基于阿里云Flink实现"精准营销"。

背景


许多互联网电商行业客户当前已经基于阿里云云原生的大数据解决方案(DataWorks、MaxCompute、Flink、Hologres)构建起离线和实时数据一体化的数据中台,为各业务线提供BI报表及数据接口支持。电商行业客户在数仓的分析场景外,也面临业务系统中的风控需求。比如:每季度的营销费用中,不少的羊毛党薅走正常用户的利益。羊毛党一方面导致可能导致用户的口碑下降,另一方面原有的活动运营预算迅速攀升从而导致资损。阿里云实时计算Flink通过特有的实时风控能力帮助客户准确识别羊毛党,防止营销预算流失。


客户的预期“实时风控”系统设计中,希望选择一款合适的"规则引擎"做为整体技术架构提供能力支撑。通过规则的动态化,多维度的规则组合来实现业务目标。“实时风控”项目一期基于 Flink 的能力,底层通过 Flink SQL 实现,支持规则上指标阈值的动态化,在初期满足风控专员的一些固定场景。随着系统实际运行后,逐渐暴露出一些开源Flink的能力不满足点,最终客户成功基于阿里云实时计算 Flink 版的企业级CEP能力落地实时风控解决方案,更近一步基于阿里云Flink实现"精准营销"。


业务需求



业务业务需求,所采用的“规则引擎”必须包含如下能力:


"精准营销"主要业务逻辑:

  1. 多种触发形式
  • 定时调度型
  • 事件触发型
  1. 用户分析

需要支持多条件的且、或关系组合

  • 用户自然属性 行为属性 统计分析

统计分析 年龄、性别、所属区域、累计,首次消费、未次消费等

  • 用户行为序列分析

做了事件 A、做了事件 A 紧接着做了事件 B、做了事件 A 且 N 分钟之后做了事件 B、做了事件 A 且 N 分钟之后没有做事件 B、没做事件 A

  1. 多种触达方式
  • 对接下游触达系统
  • 支持退出计划(单规则只触达单用户1次或 N 次,多规则只触达单用户1次或 N 次,黑白名单机制)


其中 用户分析 为配置规则的重点环节,合理的技术引擎必须能支持:

  1. 规则的在线启、停
  2. 规则的以下维度的动态化配置
  • 聚合的字段
  • 分组字段
  • 聚合函数
  • 窗口大小
  • 阈值
  • 计算符号
  • 行为序列的组合


技术实践



通过剖析需求,实时规则和离线规则的本质上是批流场景的问题:

  • 当规则时间选择为:T-1 ~ T-N,对应纯离线表
  • 当规则时间选择为:T     ~ T-N,对应离线表+实时表
  • 当规则时间选择为:T     ~ T+N,对应实时表+流式数据


客户的技术实施中还考虑了业务系统运行中的实际问题,并且将这些目标融入在平台设计中:

  • 规则变化是常见的吗?是高频的吗?

是常见的,但不是高频的。规则的变化通常是由于业务策略发生变化,类似表结构的变化,业务中比较常见,但并不是高频的修改。

  • 当规则个数为0时,直接丢弃数据,是否可以满足用户需求?

可以丢弃数据。基于业务需求,先有规则,再有规则的计算。

  • 当规则被删除/更新之后,直接丢弃部分匹配事件,是否可以满足用户需求?

可以丢弃部分匹配事件

  • 是否需要通知机制,知道当前规则生效/更新等状态变化?

不需要。但设计上应该将 执行引擎 和 规则描述 分开在两个系统中,以便能直接查看到现有的规则。可以通过一条特殊的规则如"Export All Rules"导致出有存量规则信息(含规则ID,规则内容,规则状态)。

  • 是否需要多规则?

如果需要多规则、是否所有规则的 Key 是一样的

如果需要多规则、两层结构是否可以满足需求

如果需要多规则,是否有需求,某些数据只针对特定规则生效

需要多规则,且不同规则的 Key 可能不一致。即动态 KeyBy。例如:

规则

聚合字段

Rule1

{member_id: A}

Rule2

{member_id: A; shop_id:E01}

  • 是否还有其他需求?

规则在定义时是否能指定 Flink 内置的特定累加器和需要累计的字段

  • 统计型规则如何和 CEP 在同一个 Flink Job 内完成对接?

通过 CEP 动态规则(含累加器选择)将纯统计规则看作是特定的 CEP 场景


针对其中流式序列型数据,开源Apache Flink CEP 实现有两个困难点

  • Flink 社区现有的 CEP API 不支持动态改 Pattern(无法满足上层规则中台、风控中台的可集成性)
  • Flink 社区现有的 CEP API 不支持时间驱动状态跳变


阿里云工程师和客户共同攻坚,使用阿里云 Flink 的方案顺利落地。其中特别是 Flink + Hologres 提供的动态CEP规则替换能力,完美弥补了开源Flink能力的局限。规则作业发布后线上持续运行期间修改规则条件和规则阈值,不需要进行任务发布和重启。

  • 将 Flink作业逻辑开发 和 规则描述 两者完全解耦开
  • 规则描述存储在Hologres中,便于查看规则状态和历史版本
  • 规则变化时只修改Hologres中的规则,Flink自动加载完成规则更新
  • 结合Flink生态,可以轻松扩展事件源组件和事件写出组件
  • 结合Flink分布式能力,可以大规模扩展到上千并发度



该技术方案已经顺利在客户上线并在生产环境应用,在该方案中并不引入新的技术组件和编程语言,最大化复用Flink资源来实现新业务场景,降低了新组件可能引入的潜在运维风险。另一方面也极大降低了团队的学习成本,将实时计算的人力最高效的释放出来。


未来规划


关于阿里云实时计算Flink在风控方向的未来规划将围绕三个主要方向展开:

  1. Flink CEP能力的进一步增强
  2. Flink CEP SQL的动态能力
  3. Flink + DSL的Native支持(目前已提供 Flink + Drools 预览版能力
相关实践学习
基于Hologres轻松玩转一站式实时仓库
本场景介绍如何利用阿里云MaxCompute、实时计算Flink和交互式分析服务Hologres开发离线、实时数据融合分析的数据大屏应用。
Linux入门到精通
本套课程是从入门开始的Linux学习课程,适合初学者阅读。由浅入深案例丰富,通俗易懂。主要涉及基础的系统操作以及工作中常用的各种服务软件的应用、部署和优化。即使是零基础的学员,只要能够坚持把所有章节都学完,也一定会受益匪浅。
相关文章
|
2月前
|
SQL 存储 API
Flink实践:通过Flink SQL进行SFTP文件的读写操作
虽然 Apache Flink 与 SFTP 之间的直接交互存在一定的限制,但通过一些创造性的方法和技术,我们仍然可以有效地实现对 SFTP 文件的读写操作。这既展现了 Flink 在处理复杂数据场景中的强大能力,也体现了软件工程中常见的问题解决思路——即通过现有工具和一定的间接方法来克服技术障碍。通过这种方式,Flink SQL 成为了处理各种数据源,包括 SFTP 文件,在内的强大工具。
157 15
|
17天前
|
消息中间件 监控 数据可视化
实时计算Flink场景实践和核心功能体验
本文详细评测了阿里云实时计算Flink版,从产品引导、文档帮助、功能满足度等方面进行了全面分析。产品界面设计友好,文档丰富实用,数据开发和运维体验优秀,具备出色的实时性和动态扩展性。同时,提出了针对业务场景的改进建议,包括功能定制化增强、高级分析功能拓展及可视化功能提升。文章还探讨了产品与阿里云内部产品及第三方工具的联动潜力,展示了其在多云架构和跨平台应用中的广阔前景。
51 9
|
18天前
|
运维 监控 安全
实时计算Flink场景实践和核心功能体验
实时计算Flink场景实践和核心功能体验
|
19天前
|
运维 数据可视化 数据处理
实时计算Flink场景实践和核心功能体验 评测
实时计算Flink场景实践和核心功能体验 评测
42 4
|
8天前
|
数据采集 运维 搜索推荐
实时计算Flink场景实践
在数字化时代,实时数据处理愈发重要。本文分享了作者使用阿里云实时计算Flink版和流式数据湖仓Paimon的体验,展示了其在电商场景中的应用,包括数据抽取、清洗、关联和聚合,突出了系统的高效、稳定和低延迟特点。
36 0
|
2月前
|
消息中间件 canal 数据采集
Flink CDC 在货拉拉的落地与实践
陈政羽在Apache Asia Community Over Code 2024上分享了《货拉拉在Flink CDC生产实践落地》。文章介绍了货拉拉业务背景、技术选型及其在实时数据采集中的挑战与解决方案,详细阐述了Flink CDC的技术优势及在稳定性、兼容性等方面的应用成果。通过实际案例展示了Flink CDC在提升数据采集效率、降低延迟等方面的显著成效,并展望了未来发展方向。
527 14
Flink CDC 在货拉拉的落地与实践
|
1月前
|
SQL 消息中间件 分布式计算
大数据-130 - Flink CEP 详解 - CEP开发流程 与 案例实践:恶意登录检测实现
大数据-130 - Flink CEP 详解 - CEP开发流程 与 案例实践:恶意登录检测实现
37 0
|
2月前
|
运维 数据处理 数据安全/隐私保护
阿里云实时计算Flink版测评报告
该测评报告详细介绍了阿里云实时计算Flink版在用户行为分析与标签画像中的应用实践,展示了其毫秒级的数据处理能力和高效的开发流程。报告还全面评测了该服务在稳定性、性能、开发运维及安全性方面的卓越表现,并对比自建Flink集群的优势。最后,报告评估了其成本效益,强调了其灵活扩展性和高投资回报率,适合各类实时数据处理需求。
|
10天前
|
存储 分布式计算 流计算
实时计算 Flash – 兼容 Flink 的新一代向量化流计算引擎
本文介绍了阿里云开源大数据团队在实时计算领域的最新成果——向量化流计算引擎Flash。文章主要内容包括:Apache Flink 成为业界流计算标准、Flash 核心技术解读、性能测试数据以及在阿里巴巴集团的落地效果。Flash 是一款完全兼容 Apache Flink 的新一代流计算引擎,通过向量化技术和 C++ 实现,大幅提升了性能和成本效益。
625 10
实时计算 Flash – 兼容 Flink 的新一代向量化流计算引擎
|
3月前
|
SQL 消息中间件 Kafka
实时计算 Flink版产品使用问题之如何在EMR-Flink的Flink SOL中针对source表单独设置并行度
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。

相关产品

  • 实时计算 Flink版
  • 下一篇
    无影云桌面