带你读《Elastic Stack 实战手册》之72:——4.1.4.基于Elasticsearch构建业财数据实时聚合搜索的发布平台

本文涉及的产品
Elasticsearch Serverless通用抵扣包,测试体验金 200元
简介: 带你读《Elastic Stack 实战手册》之72:——4.1.4.基于Elasticsearch构建业财数据实时聚合搜索的发布平台

4.1.4.基于Elasticsearch构建业财数据实时聚合搜索的发布平台


创作人:赵禹光

审稿人:杨丛聿

 

贝壳找房签约数据中心对接着订单、账单与业绩等几十个签约业财核心系统,需要同时处理上百种业务类型的签约标准数据。面临业务数据不及时、签约数据中心的标准财务数据转化为业务需求数据周期长等问题,与此同时,随着接入数据呈现指数级增长,通过数据库中间件实现的分表方案不仅维护成本高,而且在搜索场景有很大限制。稍有不慎,搜索策略就会变成广播模式,这种情况下,进行数据搜索,不仅对资源消耗高,而且用户体验也不友好。此外,在运营决策分析场景和作业数据查询场景,传统的输出方案 T+1 的时效性不佳,满足不了业务需求。故此,寻找一款成熟的搜索型数据库,成为了数据中心的数据库选型方向。

 

建设背景

 

随着互联网数字时代的到来,上亿的数据量级成为了常态,面对海量数据,高并发搜索的挑战,贝壳找房签约数据中心采用基于“数据流预聚合 + Elasticsearch 搜索”方案,构建起一套支持准实时、高可用、高并发的分布式搜索解决方案。

 

2021年起,该系统对接了贝壳业财多个核心系统,同时处理着几十种业务类型数据。并且,业财数据的搜索场景,通常有查询场景复杂,原始数据离散,数据量级成指数趋势上升的特点。寻找一款成熟的,能够支撑海量数据实时检索的数据库成为了签约数据中心的选型方向。

 

根据自身业务的发展诉求,以数据实时性、数据量级、搜索能力三个核心指标进行横向对比,最终选型 Elasticsearch 构建数据中心,实现一套拆解需求精准,发布接口快速的解决方案。

 

架构概述


image.png


纵观架构,我们将需求场景拆解为数据中心的典型“三明治”架构

 

l 上层“业务系统层”的查询场景统一由“数据服务层”提供

l “数据服务层” 在其中起到桥接枢纽的作用,“标准中台层” 灌入的数据通过时间窗口和 “Ingest Pipeline” 技术,将数据流里的数据预聚合起来,并持续写入 Elasticsearch

l 底层 “标准中台层” 对接各个项目的独立数据流,将数据以流式灌入数据服务层。

 

在“数据服务层”发布平台接口时,通过基于“Search Template”构建的 ORM 框架,不仅解决了由于搜索技术壁垒带来的对接难问题,也收口了数据服务层性能迭代优化升级带来的前后不兼容问题。下面通过几个核心收益来介绍核心技术点。

 

核心收益


数据构建能力

 

对于上亿量级的数据存储,通过在数据模型中定义不可变的时间戳字段,将数据划分为多个时序索引,确保单个索引的数据量级在千万级以下。并且在业务层搜索时,确保参数带上不可变的时间戳查询范围,用以缩小搜索涉及的索引范围,避免无效的性能浪费。通过索引生命周期规划,大幅度降低了建设和维护成本,很好的满足了业务要求,2021年初至今,满足月数据增长量上亿的场景需求,实现了数据轻量级处理,与存储能力的弹性扩容,整体性能很好的满足了业务的需求。

 

业务数据通常存储在关系型数据库中,业财数据也是如此,所以 “标准中台层” 系统发出的事件流中的数据大多都是基于行式存储的。基于 Elasticsearch 的 “Ingest Pipeline” 技术,在数据流预聚合后,可实现业务数据构建中“列转行”等负载构建处理能力。

 

搜索需求拆解能力

 

构建 Elasticsearch 索引有很多关键参数,这些参数不仅会影响用户体验,还会影响集群的整体性能,为了更好的将人类语言(搜索需求)拆解为机器语言(关键参数),通过如下两个关键点进行拆解:

 

l refresh_interval 控制在 2s 到 10s,来区分需求方是业务作业用户还是经营管理用户。对于作业类搜索需求,配置为 2s,可以实现平均 1s 的信息时延体感,用户几乎无感知,经营管理类的搜索场景,设定为 10s 是为了更快地摄入大量的数据,主要解决快速响应“数据钻取”等复杂决策搜索需求,同时使用 Elasticsearch 又可以规避大数据引擎“T+1”时延问题。

l 搜索速度的提升,最有效的方式就是缩小数据范围。在规划 Elasticsearch 索引时,根据搜索场景,通过搜索入参,可以有效的缩小数据的搜索范围。通过时序索引和指定路由,来拆解上亿数据量级的数据搜索;或根据搜索场景,限制作业人员地理区域,进行垂直切割索引,都是有效的提升搜索性能的手段,Elasticsearch 作为一个分布式搜索引擎,在存储大数据量级的数据时,使用“分而治之”的思路,将海量数据通过分索引或多分片的方式进行数据拆分,使用并行技术来处理海量数据的存储和搜索。


一致性约束能力

 

众所周知,Elasticsearch 大量数据写入,是通过 _bulk API 写入内存,然后定期存储到磁盘中,所以批量数据写入的原子性是不具备的,但对于典型的费用明细查询场景,一笔费用的所有明细必须同时出现,不允许给用户展示某一版本的部分费用明细。因此,对于需要具备强一致性约束的列表搜索页,我们使用嵌套(nested)结构+内存分页+块状导出,以上三个关键能力来实现数据服务的一致性约束能力的闭环建设。

 

l 嵌套(nested)结构的根(父级 ID),为一笔费用的最新版本,通过更新 _bulk API,同批次写入全部的嵌套(nested)结构数据,确保在同一版本下的明细数据具备一致性约束能力。

l 内存排序与 Elasticsearch max_result_window 配置项的设计初衷一致,大多数搜索场景下,用户只想得到相关度较高的结果。所以通过一次排序搜索嵌套数据,将 inner_hits 数据存储至内存队列结构,根据用户的分页请求进行分页处理。

l 块状导出:对于数据没有相关度算分的场景,如:导出数据,通过 Search After 功能即可实现块状数据导出。


接口发布能力

 

互联网数据存储相关的知识比较庞杂,大部分程序员更精通事务存储相关知识,而对搜索层面的认知参差不齐。这严重影响了对接搜索能力的进程,为了提高搜索接口的发布能力,需要解决如下两个难点:

 

l MySQL关系型数据库查询接口的迁移

l 统一对接 Elasticsearch 方式,快速发布对索引的查询接口

 

通过调研,我们最终选取了在数据搜索服务中使用搜索模板(Search Template)来构建 ORM框架,接入方不用关注搜索知识,通过简单转移关系型语句可以做到低成本迁移,目前已对接的业务方,甚至都感受不到在使用搜索引擎。具体示例对接过程如下:


image.png


l 现有的业务系统,通过搜索对象(Search DTO),使用如 Mybatis 等 ORM 框架对存储在关系型数据库中的数据进行搜索,如图中上部分所示

l 在对接签约数据中心后,只需要将 Mybatis 查询模板,映射成 Elasticsearch 的搜索模板

l (Search Template),通过 HTTP 调用方式,即可快速发布查询接口。

 

业务线对签约数据中心,前后的交互方式几乎没有变化,而且对接过程完全通过发布平台自动化实现发布,业务线人员,对接前后完全感知不到 Elasticsearch 复杂的技术生态。

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
|
人工智能 运维 自然语言处理
如何在 Elasticsearch 中构建你的智能 AI 助手?
随着微服务、容器化和云原生架构的发展,系统日志量呈指数增长。传统人工排查和固定规则告警方式已难以应对,导致日志查不准、异常发现慢等问题,影响系统稳定性和运维效率。本文介绍如何基于 Elasticsearch 构建具备自然语言理解、异常检测和安全威胁识别能力的智能运维 AI 助手,帮助将 Elasticsearch 从“日志仓库”升级为“智能决策中枢”,提升运维智能化水平与操作效率。
|
4月前
|
存储 机器学习/深度学习 人工智能
使用 LangChain + Higress + Elasticsearch 构建 RAG 应用
本文介绍了如何利用LangChain、Higress和Elasticsearch快速构建RAG(检索增强生成)应用,实现企业知识的智能检索与问答。首先通过LangChain解析Markdown文档并写入Elasticsearch,接着部署Higress AI网关并配置ai-search插件以整合私有知识库与在线搜索功能。最后,通过实际案例展示了RAG查询流程及结果更新机制,确保内容准确性和时效性。文章还提供了相关参考资料以便进一步学习。
472 38
|
4月前
|
存储 安全 Linux
Elasticsearch Enterprise 9.0 发布 - 分布式搜索和分析引擎
Elasticsearch Enterprise 9.0 (macOS, Linux, Windows) - 分布式搜索和分析引擎
198 0
|
4月前
|
存储 Linux iOS开发
Elasticsearch Enterprise 8.18 发布 - 分布式搜索和分析引擎
Elasticsearch Enterprise 8.18 (macOS, Linux, Windows) - 分布式搜索和分析引擎
120 0
|
6月前
|
数据采集 JSON 数据挖掘
Elasticsearch 的DSL查询,聚合查询与多维度数据统计
Elasticsearch的DSL查询与聚合查询提供了强大的数据检索和统计分析能力。通过合理构建DSL查询,用户可以高效地搜索数据,并使用聚合查询对数据进行多维度统计分析。在实际应用中,灵活运用这些工具不仅能提高查询效率,还能为数据分析提供深入洞察。理解并掌握这些技术,将显著提升在大数据场景中的分析和处理能力。
261 20
|
8月前
|
人工智能 自然语言处理 搜索推荐
云端问道12期实操教学-构建基于Elasticsearch的企业级AI搜索应用
本文介绍了构建基于Elasticsearch的企业级AI搜索应用,涵盖了从传统关键词匹配到对话式问答的搜索形态演变。阿里云的AI搜索产品依托自研和开源(如Elasticsearch)引擎,提供高性能检索服务,支持千亿级数据毫秒响应。文章重点描述了AI搜索的三个核心关键点:精准结果、语义理解、高性能引擎,并展示了架构升级和典型应用场景,包括智能问答、电商导购、多模态图书及商品搜索等。通过实验部分,详细演示了如何使用阿里云ES搭建AI语义搜索Demo,涵盖模型创建、Pipeline配置、数据写入与检索测试等步骤,同时介绍了相关的计费模式。
216 3
|
8月前
|
人工智能 算法 API
构建基于 Elasticsearch 的企业级 AI 搜索应用
本文介绍了基于Elasticsearch构建企业级AI搜索应用的方案,重点讲解了RAG(检索增强生成)架构的实现。通过阿里云上的Elasticsearch AI搜索平台,简化了知识库文档抽取、文本切片等复杂流程,并结合稠密和稀疏向量的混合搜索技术,提升了召回和排序的准确性。此外,还探讨了Elastic的向量数据库优化措施及推理API的应用,展示了如何在云端高效实现精准的搜索与推理服务。未来将拓展至多模态数据和知识图谱,进一步提升RAG效果。
295 1
|
8月前
|
数据采集 人工智能 运维
从企业级 RAG 到 AI Assistant,阿里云Elasticsearch AI 搜索技术实践
本文介绍了阿里云 Elasticsearch 推出的创新型 AI 搜索方案。
704 5
|
4月前
|
JSON 安全 数据可视化
Elasticsearch(es)在Windows系统上的安装与部署(含Kibana)
Kibana 是 Elastic Stack(原 ELK Stack)中的核心数据可视化工具,主要与 Elasticsearch 配合使用,提供强大的数据探索、分析和展示功能。elasticsearch安装在windows上一般是zip文件,解压到对应目录。文件,elasticsearch8.x以上版本是自动开启安全认证的。kibana安装在windows上一般是zip文件,解压到对应目录。elasticsearch的默认端口是9200,访问。默认用户是elastic,密码需要重置。
1724 0
|
5月前
|
安全 Java Linux
Linux安装Elasticsearch详细教程
Linux安装Elasticsearch详细教程
751 1

相关产品

  • 检索分析服务 Elasticsearch版