机票分享第六篇 机票搜索系统演进的经验

简介: 机票业务非常复杂,我们不得不应对这些复杂,也不断的想出一些招数演进系统。我回顾所做的事,再次思考并归纳核心思路,完成了本篇。 一、最大化统一,最小化变化 业务复杂,更不能随意新增接口、流程,思考如何将不同场景的流程融合在一起。


机票业务非常复杂,我们不得不应对这些复杂,也不断的想出一些招数演进系统。我回顾所做的事,再次思考并归纳核心思路,完成了本篇。


一、最大化统一,最小化变化

业务复杂,更不能随意新增接口、流程,思考如何将不同场景的流程融合在一起。

773e141073d76940a8439d6e62e537b6ac635e6e

图例:逐级搜索机票展示结果

航班页、低价页、填写页没人会拆成三个流程分别实现,尽可能提取出不变的部分,将变化降到最低。低价页支持填充坑位的需求之前,排序层统一做合并;之后,排序层统一做坑位填充。

1e879db70b6075b190964dcfb1cadd2904deb370

配图:低价页需要支持填充坑位,那航班页也采用填充方式

流程所经过的分层、步骤是统一的,一些细节的操作是变化的。


航班页

低价页

填写页

过滤条件

出发、到达、出发日期

+航班号

+代理商、舱位、产品

产品计算层

最低价产品

排序层需要展示的产品

选中的产品

排序层-填充阶段

每个航班选最低价

对每个坑位按指定优先级填充产品

-

排序层-排序阶段

价格由低到高

定义的坑位顺序

-

校验层

-

-

与数据库校验

表格:每一层变化的部分


二、标准化,模块化,配置化

随着不断新增的业务场景,被动引入各种类型的变化,流程越改越乱,配置纠缠不清。直到有一天老板也看不下去了:“你们只会加那不叫本事,敢于删才叫本事”。但要怎么删呢?

8b78015f7b9a80781ba1851219f4856cde3a0114

配图:各种ifelse,各种配置,乱作一团

不同来源对应不同变化,将散乱的来源标准化,用以规范变化的引入。

将同类变化提炼到一起,固化成业务上内聚的模块。

将提练后剩下的真正变化采用配置的形式。

c88303bf80dea40274f17e8713275907cdf1d454

配图:变化来源的三大类别,渠道、人群、搜索模式;变化行为属于平台控制的各个业务模块

渠道的定义“端、容器、入口”并不是包含关系,而是组合。像改签搜索、机票宝贝搜索相关的一类需求,我们称作入口。

这样一来,航司限价的代码是通用的,变化的只是对“API-MTOP-外采”设置所有航司不限,对“无线-APP-小搜”配置限价航司。流程是通用的,变化被配置化。


三、产品化

航司限价有了针对不同渠道、人群的配置,配置是否对业务方足够透明,使其完全了解业务含义,并独立修改呢?由研发人员修改的配置只是另外形式的代码,被业务方使用的配置才是可控的产品。

曾经排查线上特定商品不展示问题,有段业务逻辑把该商品干掉了,运营根本不知道有这个功能,只有代码自己知道。

不断迭代的需求,不断引入的变化,缺少输出、无法控制,代码静静的躺在那里,有多可怕。


前面提到的都是引入变化的技巧。复杂的业务往往对应更多的模块、分层、系统,后面谈谈边界及交互的思路。


四、明晰边界

做划分通常会遵从高内聚、低耦合的标准,实际操作时往往没那么简单,时不时会遇到些模棱两可的情况。

1、改签流程中,交易与搜索系统的边界

计算改签费用放在哪做成为争论的焦点。只返回将改签到的商品的官方指导价,还是算出改签客户要付的费用来?最终结论是计算改签费用放在交易。因为搜索系统是无状态的,而订单是有状态的,所以和状态相关(比如二次改和一次改手续费算法不同)的逻辑放在交易系统更合适。也许这次的需求只支持一次改,只是一个固定的手续费,但一定要把潜在引入的变化考虑进去。对于本例,我们找出了两个系统不同的本质特性“状态”,从而判断出功能适合内聚到哪。

ad1a88093778f89bbdeac4ac9908af2de97c6aeb

配图:搜索要支持改签按航司规定的过滤(蓝色),该不该支持改签费用计算(绿色)?

2、特殊优惠展示成划价,放在搜索还是营销系统?

营销已经实现了用划价展示已减优惠(营销系统知道);新增的特殊优惠(搜索系统知道、营销系统不知道)希望展示成划价的形式。如果只考虑工作量,让营销系统把特殊优惠也作为一种优惠来处理,复用划价展示的逻辑。另外的做法是搜索也支持划价展示,相当于展示层需要感知搜索、营销两者的划价展示。是否放到营销的关键点是确定系统边界,是不是以后所有的减价形式都算营销?


e1bd019f62c7dab85a1262a585bc062d251a60eb

配图:最终采用的方案,搜索告诉营销系统动态新增特殊优惠的活动(绿色)

直到项目做完我心里也没有定论,用的是不是最合理的方案。似乎放在搜索合理一些,但如果仅仅为支持这一个业务场景去改动,考虑的还不够全面。


五、统一交互

交互时始终使用同一种语言才方便,机票搜索本质是商品的搜索,需要统一的商品模型,我们实际做的还不够。

1、搜索系统在填单页把商品快照给交易系统,商品模型不够完善,不包含“是否验价”、“验价的office号”、“是否自动占座”等信息,交易系统需要自己判断从哪个基础数据上获取相应信息。

24a85021b665efe6b979ee76f980fbec0f8e974a

配图:商品快照,一半是商品模型,一半是数据库对象

2、国内与国际搜索商品模型不统一,造成营销需要分别为国际国内提供二方包。

f2ac86c5096c548f875bf916780a71399f9e981b

配图:营销分别提供国内、国际工具,来匹配不同格式的机票商品

试想如果有统一的机票商品模型,这些流程会方便很多,国内与国际的联程拼接实现起来也会简单许多。

目录
相关文章
|
2月前
|
监控 搜索推荐 数据挖掘
电子邮件营销新风潮:五步高效撰写EDM文案
构建成功的EDM邮件营销策略涉及理解目标受众、设定营销目标、创建吸引人的主题、个性化内容和情感共鸣、强调价值点、以及持续测试和优化。了解受众特征和行为以定制文案,使用生动语言制造兴趣,通过个性化和情感化元素增强连接,突出产品优势并设置明确的行动号召。运用A/B测试评估文案效果,并监控数据以优化营销表现。Zoho Campaigns等工具可提供支持,包括模板、编辑器和A/B测试功能,助力打造高效邮件营销文案。
57 1
|
8月前
|
搜索推荐 SEO
搜索口碑优化 是现代网络营销不可或缺的一部分
搜索口碑现代网络营销不可或缺的一部分,特别是品牌搜索形象的优化是品牌方最为关注的重点之一。随着竞争的加剧,企业必须确保他们的产品或服务在搜索引擎结果中的排名尽可能地靠前,同时也必须保持自身品牌形象的丰满和调性。
|
10月前
|
安全
dapp预约抢单排单互助系统开发逻辑详细/功能说明/案例分析/方案规则/源码出售
Allow users to register accounts and verify their identities to ensure that the identities of participants are valid and authentic.
|
2月前
|
新零售 人工智能 大数据
东郊到家预约服务系统开发|现成案例|模式详情
由于线下门店的商品陈列和消费者行为发生在物理空间里,线下门店想收集数据似乎没那么容易
|
区块链
DAPP画室/书画/字画古董拍卖竞拍抢拍商城系统开发(案例设计)/项目逻辑/成熟技术/方案介绍/源码说明
智能合约是DAPP的核心组成部分,它是一种自执行的计算机代码,It can ensure that any transaction is validated and executed.智能合约提供了一种区块链上的可编程机制,通过编写代码,将一系列的条件和操作映射到智能合约中,To achieve management and control of data and transactions on the blockchain.
|
12月前
|
存储 前端开发 区块链
区块链农场养成种植种树游戏系统开发方案介绍/功能详情/项目源码
区块链技术的兴起,为游戏开发带来了新的思路和玩法。其中,区块链农场养成种植种树游戏系统是一种利用区块链技术实现虚拟农场种植的游戏。玩家可以通过购买种子、种植、收获、交易等方式,体验虚拟农场的乐趣,同时也可以参与到环境保护和可持续发展的过程中。下面,我们将详细介绍区块链农场养成种植种树游戏系统开发方案、功能详情以及项目源码。
165 0
|
缓存 算法 搜索推荐
618省心凑背后的新算法——个性化凑单商品打包购推荐
作为购物导购链路的一个重要环节,凑单旨在快速帮助用户找到达成某个满减门槛(比如满300减50)的商品,完成性价比最高的跨店组合结算。
650 0
618省心凑背后的新算法——个性化凑单商品打包购推荐
|
小程序 安全 图形学
课程设计项目——基于3D建模技术的车位在线销售平台(序言)
课程设计项目——基于3D建模技术的车位在线销售平台(序言)
|
数据挖掘 API
淘宝商品数据分析怎么操作?从哪些方面下手?
淘宝商品数据分析怎么操作?从哪些方面下手?
阿云漫画 | 淘宝“2021年度十大商品”,你get过几件?
编者按: 2021年还有29小时30分钟就要结束了,该用什么记录这一年?继各大平台陆续发布年度关键词、热搜、弹幕之后,国民电商平台淘宝也发布了一份特殊的年度榜单。网友看完表示,“这一年的人间烟火味都在这了。”
142 0