当前位置:首页 > 文章列表 > Golang > Go问答 > 如何使用这种架构复制 Elastic Search 中的索引?

如何使用这种架构复制 Elastic Search 中的索引?

来源:stackoverflow 2024-03-17 09:36:29 0浏览 收藏

为了解决将大量数据导入数据库并快速检索的问题,本文介绍了一个使用 Go 语言、AWS SQS、Elastic Search 和 REST API 的架构。然而,作者面临着如何替换现有数据以更新为新数据的挑战。本文提出了使用索引别名的方法,该方法涉及创建一个临时索引,然后将其替换为原始索引,从而实现无缝数据切换,同时最大限度地减少磁盘空间使用。

问题内容

我有一个场景,我必须从多个源导入数据(数百万条记录)并将其保存在数据库中。当用户尝试搜索与该数据相关的任何信息时,应该会在 2-3 秒内获得结果。

为此,我设计了一个架构,使用 golang 从多个源导入数据并将数据推送到 AWS SQS 中。我创建了一个 lambda 函数,当 AWS SQS 有一些数据时会触发该函数。然后,此 lambda 函数将数据推送到 AWS Elastic Search 中。我创建了一个 Rest API,用它向用户提供结果。

我每天早上都使用 CRON 来完成这项导入工作。现在我的问题是,如果有一批新数据到来,我想删除现有数据并用新数据替换所有数据。 我陷入了如何实现删除和添加新数据部分的困境。

我想到创建一个临时索引,然后用原始索引替换它。但问题是我不知道导入何时结束并可以进行此索引切换。


解决方案


您想要的概念是 index alias。基本工作流程是:

  1. 将今天的数据导入到带有 my-index-2019-09-16 的索引中(例如)。
  2. 确保导入完成且工作正常。
  3. 将别名指向新索引(这是索引之间的原子切换):

    POST /_aliases
    {
        "actions" : [
            { "remove" : { "index" : "my-index-2019-09-15", "alias" : "my-index" } },
            { "add" : { "index" : "my-index-2019-09-16", "alias" : "my-index" } }
        ]
    }
  4. 删除旧索引。

您将在导入过程中将磁盘空间增加一倍,但除此之外,这应该不会出现任何问题,并且只有在正确替换数据后才删除数据。

今天关于《如何使用这种架构复制 Elastic Search 中的索引?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
在具有 Cognito 身份验证和 API 网关的 Go lambda 函数中,CognitoIdentityID 为空在具有 Cognito 身份验证和 API 网关的 Go lambda 函数中,CognitoIdentityID 为空
上一篇
在具有 Cognito 身份验证和 API 网关的 Go lambda 函数中,CognitoIdentityID 为空
小米14 Ultra搭载徕卡双长焦,手机摄影再迎新篇章
下一篇
小米14 Ultra搭载徕卡双长焦,手机摄影再迎新篇章
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 畅图AI:AI原生智能图表工具 | 零门槛生成与高效团队协作
    畅图AI
    探索畅图AI:领先的AI原生图表工具,告别绘图门槛。AI智能生成思维导图、流程图等多种图表,支持多模态解析、智能转换与高效团队协作。免费试用,提升效率!
    6次使用
  • TextIn智能文字识别:高效文档处理,助力企业数字化转型
    TextIn智能文字识别平台
    TextIn智能文字识别平台,提供OCR、文档解析及NLP技术,实现文档采集、分类、信息抽取及智能审核全流程自动化。降低90%人工审核成本,提升企业效率。
    11次使用
  • SEO  简篇 AI 排版:3 秒生成精美文章,告别排版烦恼
    简篇AI排版
    SEO 简篇 AI 排版,一款强大的 AI 图文排版工具,3 秒生成专业文章。智能排版、AI 对话优化,支持工作汇报、家校通知等数百场景。会员畅享海量素材、专属客服,多格式导出,一键分享。
    11次使用
  • SEO  小墨鹰 AI 快排:公众号图文排版神器,30 秒搞定精美排版
    小墨鹰AI快排
    SEO 小墨鹰 AI 快排,新媒体运营必备!30 秒自动完成公众号图文排版,更有 AI 写作助手、图片去水印等功能。海量素材模板,一键秒刷,提升运营效率!
    12次使用
  • AI Fooler:免费在线AI音频处理,人声分离/伴奏提取神器
    Aifooler
    AI Fooler是一款免费在线AI音频处理工具,无需注册安装,即可快速实现人声分离、伴奏提取。适用于音乐编辑、视频制作、练唱素材等场景,提升音频创作效率。
    11次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码