如何获得携程同样数据可以对接数据

携程作为国内OTA领头羊每天都遭受着严酷的欺诈风险,个人银行卡被盗刷、账号被盗用、营销活动被恶意刷单、恶意抢占资源等

目前携程利用自主研发的风控系统有效識别、防范这些风险。携程风控系统从零起步经过五年的不断探索与创新,已经可以有效覆盖事前、事中、事后各个环节也从原来基於“简单规则+DB”,发展到目前能够支撑10X交易增长的智能化风控系统基于规则引擎、实时模型计算、流式处理、M/R、大数据、数据挖掘、机器学习等的风控系统,拥有实时、准实时的风险决策、数据分析能力

一、Aegis系统体系

主要分三大模块:风控引擎、数据服务、数据运算、輔助系统。

  • 风控引擎:主要处理风控请求有预处理、规则引擎和模型执行服务,风控引擎所需要的数据是由数据服务模块提供的
  • 数据垺务:主要有实时流量统计、风险画像、行为设备数据、外部数据访问代理,RiskGraph数据访问层所提供的数据都是由数据计算层提供
  • 数据运算:主要包括风险画像运算、RiskSession、设备指纹、以及实时流量、非实时运算。

数据运算所需的数据来源主要是:风控Event数据(订单数据、支付数据)各个系统采集来的 UBT、设备指纹、日志数据等等。

除了这些风控平台还有非常完善的监控预警系统,人工审核平台以及 报表系统

二、Aegis系統架构

规则引擎包含3大功能,首先是适配层

由于携程的业务种类非常多,而且每种业务都有其特性在进入风控系统(Aegis)后,为了便于整个風控系统对数据进行处理风控前端有一个适配器模块,把各个业务的数据都按照风控内部标准化配置进行转换以适合风控系统使用。

茬完成数据适配后风控系统要进行数据的合并。

举个例子当有一笔支付风控校验,支付BU只抛过来支付信息(支付金额、支付方式、订单號等)但是不包含订单信息,这个时候就必须根据支付信息快速的查找到订单信息并把这两个数据进行合并,以便规则、模型使用大镓知道,用户从生成订单到发起支付其时间间隔从秒到天都有可能,当间隔时间短的时候就会发生要合并的数据还没有处理完,所以訂单数据从处理到落地要非常快第二部就是要快速查找到订单数据,我们为订单信息根据生成 RiskGraph可以快速精确定位到所需要的订单明细數据。

预处理在完成数据合并后就开始准备规则、模型所需要的变量、tag数据,在准备数据时预处理模块会依赖后面我们要讲解的数据垺务层。当然为了提高性能,我们为变量、tag的数据合理安排优先获取关键规则、模型所需要的变量、tag的数据。

大家知道欺诈分子的特点就是一波一波的,风控系统需要能够及时响应当发现欺诈行为后,能及时上规则防止后续类似的欺诈行为所以,制定规则需要快速、准确既然这样,那么就需要我们的规则能够快速上线而且规则人员自己就可以制定规则并上线。还有就是规则与执行规则的引擎仳较做到有效隔离不能因为规则的不合理,影响到整个引擎那么规则引擎就必须符合这些条件。

我们最后选择了开源 Drools第一它是开源,第二它可以使用Java语言入门方便,第三功能够用

这样携程风控引擎 实现了 规则 上线的高效携程风控实时引擎 通过使用 规则引擎Drools,使其具有非常高的灵活性、可配置性并且由于是java语法的,规则人员自己就可以制定规则并迅速上线

由于每个风控Event请求,都需要执行数百个規则以及模型,这时风控引擎引入了规则执行路径优化方法。建立起并行+串行依赖关系+非依赖关系的规则执行优化方法,然后再引叺短路机制使上千个规则的运行时间控制在100ms。

规则的灵活性非常强制定、上线非常快,但是单个规则的覆盖率比较低如果要增加覆蓋率就需要非常多的规则来进行覆盖,这个时候规则的维护成本就会很高那么这个时候就需要使用模型了,模型的特点就是覆盖率覆盖率可以做到比较高其模型逻辑可以非常复杂,但是其需要对其进行线下训练所以携程风控系统利用了规则、模型的各自特点进行互补。

在目前的风控系统中主要使用了:Logistic Regression、Random Forest两个算法使用下来,目前情况为:LR训练变量区分度足够好的情况下加以特征工程效果比较好。RF當变量线性区分能力较弱的时候效率比较高。所以使用RF的比例比较多

数据服务层,主要功能就是提供数据服务我们知道在风控引擎預处理需要获取到非常多的变量和tag,这些变量和tag的数据都是由数据访问层来提供的该服务层的最重要的目的就是响应快。所以在数据服務层主要使用Redis作为数据缓存区重要、高频数据直接使用Redis作为持久层来使用。

数据服务层的核心思想就是充分利用内存(本地、Redis)

1、本地内存(夶量固定数据如ip所在地、城市信息等)

2、充分利用Redis高性能缓存

由于实时数据流量服务、风险画像数据服务的数据是直接存储在Redis中,其性能能够满足规则引擎的要求我们这里重点介绍一下数据访问代理服务。

数据访问代理服务其最重要的思想就是该数据被规则调用前先调鼡第三方的服务,把数据保存到Redis中这样当规则请求来请求的时候,就能够直接从Redis中读取既然做到了预加载,那么其数据的新鲜度及命Φ率就非常重要

我们以用户相关维度的数据为例,风控系统通过对用户日志的分析可以侦测到哪些用户有登陆、浏览、预定的动作,這样就可以预先把这些用户相关的外部服务数据加载到Redis中当规则、模型读取用户维度的外部数据时,先直接在redis中读取如果不存在然后洅访问外部服务。

在某些场景下我们还结合引入DB来做持久化,当用户某些信息发生变化的时候公共服务会发送一个Message到Hermes,我们就订阅该信息当知道该用户的某些信息发生修改,我们就主动的去访问外部服务获取数据放入Redis中由于风控系统能够知道这些数据发生变化的Message,所以这些数据被持久化到DB中也是ok的当然,这些数据也有一个TTL参数来保证其新鲜度

在这种场景下,系统在Redis没有命中的情况下先到DB中查找,两个地方都不存在满足条件的数据时才会访问外部服务,这个时候其性能、存储空间就可以得到优化。

Chloro系统是数据分析服务也是整个风控系统的核心数据服务层所使用到的数据,都是由Chloro系统计算后提供的

主要分析维度主要包括:用户风险画像,用户社交关系网絡交易风险行为特性模型,供应商风险模型

实时处理系统进行处理。

当Real Time Process 和 CountServer对数据处理好后这个时候分成了两部分数据,一部分是处悝的结果还有一份是原数据,都会提交给Data Dispatcher由它进行Chloro系统内部的数据路由,结果会直接进入到RiskProfile提供给引擎和模型使用而原始数据会写叺到Hadoop集群。

Batch Process就利用Hadoop集群的大数据处理能力对离线数据进行处理,当Batch Process处理好后也会把处理结果发送给Data Dispatcher,由它进行数据路由

RiskSession的定义:量囮、刻画 用户的行为,任何人通过任何设备访问携程的第一个event开始我们认为Rsession start了,到他离开的最后一个event后30分钟之内没有任何痕迹留下我們认为Rsession end。

风控系统通过比较用户信息:Uid, 手机号, 邮箱设备信息:Fp(Fingerprint), clientId, vid, v, deviceId来判断其是否是同一个用户,通过其行为信息:浏览轨迹, 历史轨迹来判断其行为相似度

比如:用户在PC端下单、然后在手机APP里完成支付,这个对于Chloro是一个会话这个会话我们称之为风控Session,通过Risksession的定义风控系统使用户的行为可以量化,也可以刻画这样Risksession实际上可以作为用户行为的一个 Container。使用RiskSession就可以做到跨平台更加有利于分析用户特征。

Risk Graph 是根据攜程风控系统的特点开发出来的Risk Graph是一个基于HBase进行为存储介质的系统,比如以用户为节点其值就是HBase用户表的key,其每个列就是特性然后根据用户的某个特性再创建一个hbase表,这样就创建了一个基于HBase的类Graph的架构

所以该系统的一个核心思想是先创建各个维度的数据索引,然后根据索引值再进行内容的查找目前风控系统已经创建了十几个维度的快速索引。

六、Aegis其它子系统

Aegis还有配置系统用户可以在上面进行各種配置,如规则、规则运行路径标准化、tag、变量定义、已经数据清洗业务罗辑等等,当然监控系统也是非常重要的风控研发秉承着监控无处不在的设计理念,使其能够在第一时间发现系统的任何细小变化

关注大数据和大数据应用_大数据第一科技网

我要回帖

更多关于 对接数据 的文章

 

随机推荐