Logo

使用LangChain、Amazon Bedrock和OpenSearch构建高效的RAG应用

引言

随着大语言模型(LLM)技术的迅速发展,如何有效地利用这些模型来解决实际问题成为了一个热门话题。检索增强生成(Retrieval Augmented Generation, RAG)作为一种结合外部知识库的方法,能够显著提升LLM的表现。本文将介绍如何使用Amazon Web Services (AWS)的一系列服务,结合开源框架LangChain,构建一个高效的RAG应用。

RAG应用架构概览

我们的RAG应用主要由以下几个核心组件构成:

  1. Amazon Bedrock: 作为管理的基础模型服务,提供API访问各种基础模型。
  2. Amazon OpenSearch Service: 作为向量数据库,存储文档嵌入。
  3. LangChain: 作为LLM应用框架,协调各个组件的交互。
  4. Amazon Elastic Container Service (ECS): 用于运行RAG应用。
  5. Streamlit: 提供RAG应用的前端用户界面。
  6. Application Load Balancer: 路由HTTPS流量到ECS服务。
  7. Amazon Cognito: 提供安全的用户认证。

RAG应用架构图

核心技术详解

Amazon Bedrock和Titan嵌入模型

Amazon Bedrock是AWS提供的一项托管服务,让开发者能够通过API轻松访问各种基础模型。在本项目中,我们使用了Bedrock中的Titan Embeddings Generation 1 (G1)模型来生成文本嵌入。这些嵌入将被存储在OpenSearch中,用于后续的相似性搜索。

OpenSearch作为向量数据库

OpenSearch是一个开源的搜索和分析引擎,在本项目中被用作向量数据库。与Amazon Kendra等专有服务相比,OpenSearch提供了更大的灵活性和定制化空间。我们利用OpenSearch的向量引擎支持来存储和检索文本嵌入,从而实现高效的相似性搜索。

LangChain框架的应用

LangChain是一个强大的LLM应用开发框架,在本项目中发挥了关键作用。它不仅用于协调Bedrock和OpenSearch之间的交互,还被用来更新OpenSearch索引。LangChain的S3FileLoader组件使得从S3桶中提取文档内容变得简单高效。

实现步骤

  1. 环境准备

    • 安装Python 3.11.4
    • 设置虚拟环境
    • 安装必要的依赖包
    • 安装Terraform用于创建OpenSearch集群
  2. 部署基础设施

    • 使用Terraform部署OpenSearch集群
    • 设置S3桶用于存储知识库文档
    • 配置Lambda函数处理PDF文件并提取文本
  3. 数据处理和索引更新

    • 从Hugging Face下载示例数据集
    • 使用Titan嵌入模型生成文本嵌入
    • 将嵌入存储到OpenSearch中
  4. RAG应用部署

    • 部署ECS Fargate服务运行RAG应用
    • 配置Application Load Balancer
    • 设置Cognito用户池进行身份验证
  5. 使用RAG应用

    • 通过Web界面提问
    • 系统从OpenSearch检索相关嵌入
    • 使用检索到的信息增强提示,生成更准确的回答

示例用法

以下是使用不同基础模型的示例命令:

# 使用Claude v2模型
python ./ask-bedrock-with-rag.py --ask "How will AI change our everyday life?"

# 使用Claude v1.3模型
python ./ask-bedrock-with-rag.py --bedrock-model-id anthropic.claude-v1 --ask "How will AI change our everyday life?"

# 使用Jurassic-2 Ultra模型
python ./ask-bedrock-with-rag.py --bedrock-model-id ai21.j2-ultra-v1 --ask "How will AI change our everyday life?"

结论

通过结合Amazon Bedrock、OpenSearch和LangChain,我们构建了一个强大而灵活的RAG应用。这个应用不仅能够提高大语言模型的回答准确性,还为开发者提供了一个可扩展的框架,可以根据特定需求进行定制和优化。

随着AI技术的不断发展,RAG等技术将在提升AI系统性能和可靠性方面发挥越来越重要的作用。我们期待看到更多创新的应用在这个基础上涌现,为各行各业带来革命性的变革。

参考资源

通过本文的介绍,相信读者已经对如何构建一个基于AWS服务的RAG应用有了全面的了解。我们鼓励大家尝试复现这个项目,并在此基础上进行创新,开发出更多有趣且有价值的AI应用。

相关项目

Project Cover
casibase
Casibase 是一个开源AI知识库,提供类似LangChain的RAG(检索增强生成)功能,配有友好的Web UI和企业级单点登录(SSO)。支持多种AI模型,包括OpenAI、Azure、LLaMA、Google Gemini、HuggingFace、Claude和Grok等。系统包括前端(JavaScript + React)和后端(Golang + Beego + Python + Flask + MySQL),为用户提供强大的知识管理和生成能力。访问 https://casibase.org 获取更多信息和在线演示。
Project Cover
ragas
Ragas是一款工具集,用于评估、监控和优化RAG(检索增强生成)应用的性能,特别适合生产环境中的大语言模型(LLM)。Ragas集成了最新研究成果,能在CI/CD流程中进行持续检查,确保管道性能稳定。通过简单的安装和快速入门示例,用户可以快速体验Ragas的功能,并参与社区讨论LLM和生产相关问题。
Project Cover
llm-app
Pathway的LLM应用让高精度RAG AI应用快速上线,使用最新数据源。支持文件系统、Google Drive、Sharepoint、S3、Kafka、PostgreSQL等多种数据源的连接和同步,无需额外基础设施。提供多种模板,扩展至数百万页文档,满足不同需求。
Project Cover
GenerativeAIExamples
NVIDIA提供的生成式AI示例,使用CUDA-X软件栈和NVIDIA GPU,展示快速部署、测试和扩展AI模型的方法。包括最新的RAG管道构建技巧、实验性示例和企业应用,支持本地和远程推理,集成流行LLM编程框架,并附有详细开发文档。
Project Cover
Awesome-LLM-RAG
本项目汇集了最新的LLM检索增强生成(RAG)技术研究论文,包括RAG指令调优、上下文学习、嵌入、模拟、搜索、长文本与记忆、评估、优化及应用等方面。资源库为研究者提供全面参考,鼓励研究成果的提交与共享,促进RAG技术发展。
Project Cover
awesome-llm-apps
了解一系列使用OpenAI、Anthropic、Google等模型以及本地LLaMA模型构建的LLM应用,涵盖从代码库、电子邮件到投资、旅行等各个领域。这些应用通过详细的文档和开源生态系统,推动AI在多个领域的创新和发展。
Project Cover
NeumAI
Neum AI是一个数据平台,帮助开发者利用检索增强生成(RAG)技术。它从现有数据源提取数据,生成向量嵌入,并导入向量数据库进行相似性搜索。平台具有高吞吐量分布式架构,处理数十亿数据点,内置数据连接器和实时同步功能,确保数据最新,并支持元数据混合检索,提供全面的RAG解决方案。
Project Cover
ChatPDF
ChatPDF是一个基于本地LLM的文件检索和知识问答系统,支持包括PDF、docx在内的多种文件格式。系统集成了多项算法优化功能,例如Chinese chunk切分、embedding优化和检索匹配等,致力于提高RAG的准确率。此外,系统通过使用reranker模块和扩展上下文功能优化查询的精确度。基于gradio开发,该系统支持简便的Web服务启动,便于在本地环境搭建和使用。
Project Cover
korvus
Korvus是一款开源搜索SDK,将整个RAG(检索增强生成)流程整合在单个数据库查询中。基于Postgres,支持Python、JavaScript和Rust等编程语言,提供高性能且可定制的搜索功能,减少基础设施的复杂性。它结合了LLMs、向量存储、嵌入生成、重排和摘要等功能,简化搜索架构,提升性能。

最新项目

Project Cover
豆包MarsCode
豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。
Project Cover
AI写歌
Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。
Project Cover
商汤小浣熊
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
Project Cover
有言AI
有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。
Project Cover
Kimi
Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。
Project Cover
吐司
探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。
Project Cover
SubCat字幕猫
SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。
Project Cover
AIWritePaper论文写作
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。
Project Cover
稿定AI
稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。
投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号