RAG在PostgreSQL上的实现:使用Azure Container Apps和OpenAI构建智能问答系统

Ray

RAG在PostgreSQL上的实现:使用Azure Container Apps和OpenAI构建智能问答系统

随着人工智能技术的快速发展,越来越多的企业和开发者开始探索如何将AI能力整合到现有的应用系统中。本文将介绍一种基于检索增强生成(Retrieval Augmented Generation, RAG)的方案,通过结合Azure Container Apps、PostgreSQL和OpenAI,实现一个能够智能回答数据库中信息的问答系统。

RAG技术简介

检索增强生成(RAG)是一种结合了检索系统和生成模型的AI技术。它通过从知识库中检索相关信息,然后利用大语言模型生成最终答案,既保证了回答的准确性,又赋予了AI更强的推理和生成能力。在本项目中,RAG的实现主要包含以下几个关键步骤:

  1. 使用pgvector扩展对PostgreSQL数据库表进行向量化搜索
  2. 结合全文搜索,通过RRF(Reciprocal Rank Fusion)算法融合搜索结果
  3. 利用OpenAI的function calling将用户查询转换为SQL过滤条件
  4. 使用OpenAI的嵌入API将用户查询转换为向量

通过这些技术的结合,系统能够准确理解用户意图,快速检索相关信息,并生成符合上下文的自然语言回答。

系统架构概览

系统架构图

如上图所示,整个系统主要由以下几个部分组成:

  • 前端:使用React和FluentUI构建的Web应用界面
  • 后端:基于Python和FastAPI开发的API服务
  • 数据库:Azure PostgreSQL灵活服务器
  • AI服务:Azure OpenAI

整个应用通过Azure Container Apps进行部署和托管,实现了高度的可扩展性和弹性。

核心功能实现

1. 向量化搜索

本项目使用了pgvector扩展来为PostgreSQL添加向量搜索能力。首先需要在数据库中创建表并添加向量字段:

from pgvector.django import VectorField

class Transcript(models.Model):
    content = models.TextField()
    embedding = VectorField(dimensions=1536)  # OpenAI ada-002模型的维度

然后使用OpenAI的Embedding API将文本转换为向量并存储:

import openai

def generate_embedding(text):
    response = openai.Embedding.create(
        input=text, 
        model="text-embedding-ada-002"
    )
    return response['data'][0]['embedding']

transcript = Transcript(content=text)
transcript.embedding = generate_embedding(text)
transcript.save()

2. 混合搜索实现

为了提高搜索的准确性,项目结合了向量搜索和全文搜索:

from django.contrib.postgres.search import SearchVector

def hybrid_search(query, top_k=5):
    # 向量搜索
    query_vector = generate_embedding(query)
    vector_results = Transcript.objects.order_by(models.F('embedding').cosine_distance(query_vector))[:top_k]
    
    # 全文搜索
    text_results = Transcript.objects.annotate(
        search=SearchVector('content')
    ).filter(search=query)[:top_k]
    
    # 使用RRF算法融合结果
    return combine_results(vector_results, text_results)

3. 查询转换

使用OpenAI的function calling功能,可以将自然语言查询转换为结构化的SQL条件:

import openai

def convert_to_sql(query):
    response = openai.ChatCompletion.create(
        model="gpt-3.5-turbo-0613",
        messages=[{"role": "user", "content": query}],
        functions=[{
            "name": "generate_sql_condition",
            "description": "Generate SQL WHERE condition from natural language query",
            "parameters": {
                "type": "object",
                "properties": {
                    "condition": {"type": "string", "description": "SQL WHERE condition"}
                },
                "required": ["condition"]
            }
        }],
        function_call={"name": "generate_sql_condition"}
    )
    return response.choices[0].function_call.arguments

部署和运维

项目设计为可以通过Azure Developer CLI轻松部署到Azure平台:

  1. 安装Azure Developer CLI
  2. 运行azd init -t rag-postgres-openai-python初始化项目
  3. 执行azd up进行资源配置和代码部署

系统还集成了Azure Monitor,可以方便地进行应用监控和日志分析。

安全性考虑

项目采用了托管身份(Managed Identity)来进行Azure服务之间的认证,避免了硬编码凭据的安全风险。同时,建议启用GitHub的secret scanning功能,防止敏感信息泄露。

结语

通过结合Azure Container Apps、PostgreSQL和OpenAI,我们实现了一个功能强大的RAG问答系统。这种架构不仅具有良好的可扩展性和弹性,还充分利用了云原生技术的优势。希望本文能为您在构建类似AI增强型应用时提供一些有益的思路和参考。

如果您对项目有任何问题或建议,欢迎在GitHub仓库中提出issue或贡献代码。让我们一起探索AI应用的无限可能!

avatar
0
0
0
相关项目
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

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号