Skip to content

Latest commit

 

History

History
492 lines (371 loc) · 19 KB

README_zh-cn.md

File metadata and controls

492 lines (371 loc) · 19 KB

English | 简体中文

Intelli-Agent

Intelli-Agent:构建基于代理的应用程序的优化工作流

Intelli-Agent 提供一个高效简洁的工作流程,用于开发可扩展的、生产级别的、基于 agent(代理)的应用。例如:智能对话机器人等

主要功能包括:

  1. 企业知识库创建:用户可以上传各种格式的私有文档(PDF、DOCX、HTML、CSV、TXT、MD、JSON、JSONL、PNG、JPG、JPEG、WEBP)来构建个性化的知识库。

  2. 灵活的模式选项:可选择多种模式(Agent、Chat、RAG)以满足不同需求。例如,Agent 模型可以解释用户意图,选择适当的工具,并根据迭代结果采取行动。

  3. 可配置的基于聊天的用户界面:提供用户友好的聊天界面,便于配置、探索和自定义,以满足您的特定需求。

  4. 全面的 RESTful API:我们功能齐全的 API 便于与现有应用程序集成,增强功能和用户体验。

Intelli-Agent 旨在以最小的开销和最大的效率帮助开发人员快速部署智能、上下文感知的应用程序。

目录

架构

使用默认参数部署此解决方案将在 Amazon Web Services 中构建以下环境:

Architecture Image

执行过程如下:

  1. 解决方案的前端网站托管在Amazon S3桶中,通过Amazon CloudFront分发。Amazon Cognito用户池为其提供身份验证。
  2. 用户通过方案网站上传文档到知识库时,文档会首先上传到Amazon S3桶。
  3. Amazon Lambda随即被触发,并触发Amazon Step Functions处理文件。Amazon Step Functions中通过Amazon Glue Job对文档进行解析和切分,并将中间状态分别存储到Amazon DynamoDB和Amazon S3。
  4. Amazon Glue Job将切分后的文本块通过部署在Amazon SageMaker Endpoint中的Embedding模型进行向量化,并注入到向量数据库Amazon OpenSearch。其中,如果文档是图片格式(如:png,webp)或pdf格式,Amazon Glue Job会通过Amazon Bedrock理解图片并转换成文本。最后Amazon SNS会将执行结果以邮件的方式通知到用户。具体文档处理细节,请参考章节8.2.
  5. 当用户在方案网站发送聊天信息时,在线模块的Amazon API Gateway会被触发,前后端通信是通过WebSocket API实现。Amazon API Gateway集成的Amazon Lambda函数将请求消息发送到Amazon SQS防止消息超时。
  6. Amazon SQS中的消息会被在线模块的Amazon Lambda消费,根据请求参数执行Agent/RAG/Chat逻辑,并将聊天信息记录到Amazon DynamoDB。Amazon Lambda通过意图识别判断需要使用的工具,并进行相应操作。
  7. 如果选择RAG模型,Amazon Lambda通过Amazon SageMaker Endpoint中部署的Embedding模型将查询消息进行向量化,在Amazon OpenSearch中查询到匹配的知识(目前默认返回top 5知识,如需调整,请参考章节8.3),对其进行倒排,然后将知识发送给大语言模型,最后将答案返回给前端。
  8. 在聊天时,用户和AI的消息会存储在Amazon DynamoDB中,方案网站通过Amazon API Gateway和Amazon Lambda获取到某次聊天记录,用户可以基于这次聊天记录的内容继续进行聊天。

企业知识库创建

数据预处理模块包括格式识别、内容提取、元数据转换和语义分割,无缝地在后台进行。

Offline Workflow

当系统收到大量内容注入请求时,它可以通过同时运行多个 Amazon Glue 任务来自动扩展,确保这些请求及时处理。

文本块元数据

文本块元数据定义如下:

名称 描述
file_path 存储文件的 S3 路径
file_type 文件类型,例如 pdf、html
content_type 段落:段落内容
current_heading 该块所属的标题
chunk_id 唯一的文本块 ID
heading_hierarchy 用于定位整个文件内容中该块的标题层次
title 当前部分的标题
level 标题级别,例如 在 Markdown 中,H1 是 #,H2 是 ##
parent 父部分的块 ID,例如 H2 的父部分是 H1,H3 的父部分是 H2
previous 同一级别上前一段落的块 ID
child 子部分的文本块 ID
next 同一级别上下一段落的块 ID
size 段落按固定大小拆分后的文本块数量

示例:

{
	"file_path": "s3://example/intelli-agent-user-guide.pdf",
	"file_type": "pdf",
	"content_type": "paragragh",
	"current_heading": "# Intelli-Agent User Guide WebApp",
	"chunk_id": "$1-4659f607-1",
	"heading_hierarchy": {
		"title": "Intelli-Agent User Guide",
		"level": 1,
		"parent": null,
		"previous": null,
		"child": [
			"$2-038759db",
			"$4-68d6e6ca",
			"$6-e9cdcf68"
		],
		"next": null,
		"size": 2
	}
}

灵活的模式选项

下图是基于 LangGraph 生成的在线逻辑。第一个节点是 query_preprocess_lambda,它处理聊天历史记录。然后用户可以从三种模式中选择:聊天模式(chat)、检索生成模式(rag)和代理模式(agent)。聊天模式(chat) 让您可以直接与不同的 LLM(如 Anthropic Claude 3)进行交互。检索生成模式(rag) 将检索与当前查询相关的内容并让 LLM 回答。代理模式(agent) 是最复杂的模式,能够处理复杂的业务场景。根据 intention_detection_lambda 提供的最相关意图和 query_preprocess_lambda 提供的聊天历史记录,agent_lambda 将决定使用哪些工具以及这些信息是否足以回答查询。parse_tool_calling 节点将解析 agent_lambda 的输出:

  • 如果 agent_lambda 从工具格式的角度选择了错误的工具,那么会通过 invalid_tool_calling 进行重新思考。
  • 如果 agent_lambda 选择了有效工具,那么会通过 tool_execute_lambda 执行该工具。然后,agent_lambda 将决定运行结果是否足以回答查询。
  • 在某些情况下,agent_lambda 决定给出最终回应。对于需要 RAG 的情况,将调用 rag_retrieve_lambdarag_llm_lambda。对于 agent_lambda 需要更多信息的情况,将执行 give_rhetorical_question 进行反问。对于需要给出固定回复的情况,将执行 transfer_replycomfort_replygive_final_response 意味着工具调用的当前结果足以回答查询。
flowchart TD
 subgraph ReAct["ReAct"]
    direction TB
        tools_choose_and_results_generation["tools_choose_and_results_generation"]
        results_evaluation{{"results_evaluation"}}
        tools_execution["tools_execution"]
  end
    _start_["_start_"] --> query_preprocess["query_preprocess"]
    query_preprocess == chat mode ==> llm_direct_results_generation["llm_direct_results_generation"]
    query_preprocess == rag mode ==> all_knowledge_retrieve["all_knowledge_retrieve"]
    query_preprocess == agent mode ==> intention_detection["intention_detection"]
    all_knowledge_retrieve --> llm_rag_results_generation["llm_rag_results_generation"]
    intention_detection -- similar query found --> matched_query_return["matched_query_return"]
    intention_detection -- intention detected --> tools_choose_and_results_generation
    tools_choose_and_results_generation --> results_evaluation
    results_evaluation -. invalid tool calling .-> tools_choose_and_results_generation
    results_evaluation -. valid tool calling .-> tools_execution
    results_evaluation -. no need tool calling .-> final_results_preparation["final_results_preparation"]
    tools_execution --> tools_choose_and_results_generation
    llm_direct_results_generation --> _end_["_end_"]
    llm_rag_results_generation --> _end_
    matched_query_return --> final_results_preparation
    final_results_preparation --> _end_
     tools_choose_and_results_generation:::process
     results_evaluation:::process
     tools_execution:::process
     query_preprocess:::process
     llm_direct_results_generation:::process
     all_knowledge_retrieve:::process
     intention_detection:::process
     llm_rag_results_generation:::process
     matched_query_return:::process
     final_results_preparation:::process
    style query_preprocess fill:#FF6D00,color:#FFFFFF
    style ReAct fill:#FFCDD2,color:#D50000
Loading

快速开始

部署视频:

按照以下步骤开始:

  1. 预置条件
  2. 部署方案

预置条件

步骤 1: 安装所需的依赖项

执行以下命令以安装 Python、Git、npm、Docker 等依赖项,并为 Amazon OpenSearch 服务创建一个服务关联角色。如果这些依赖项已经安装,可以跳过此步骤。 setup_env.sh 脚本适配 Amazon Linux 2023,如果您使用其他操作系统,请手动安装这些依赖。

wget https://raw.githubusercontent.com/aws-samples/Intelli-Agent/dev/source/script/setup_env.sh
sh setup_env.sh

步骤 2: 安装 AWS CLI

如果您还没有安装 AWS CLI,请执行以下命令安装。

curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
unzip awscliv2.zip
sudo ./aws/install

您可以执行以下命令查看 AWS CLI 版本:

aws --version

部署方案

要部署该解决方案,请按照以下步骤操作:

步骤 1: 克隆 GitHub 仓库

git clone [email protected]:aws-samples/Intelli-Agent.git

步骤 2: 进入 source/infrastructure 目录

cd Intelli-Agent/source/infrastructure

步骤 3: 安装项目依赖

npm install

步骤 4: 运行配置命令以设置所需功能的解决方案:

npm run config

您将被提示输入以下信息:

  • Prefix: 解决方案堆栈名称的前缀。此前缀将添加到解决方案创建的所有资源中。
  • SubEmail: 接收通知的电子邮件地址。
  • KnowledgeBase: 启用或禁用知识库功能。
  • KnowledgeBaseType: 选择要启用的知识库类型。
  • Chat: 启用或禁用聊天功能。
  • Connect: 启用或禁用Amazon Connect集成,您可以使用本方案回复Amazon Connect中的信息。
  • Model: 选择要用于解决方案的模型。
  • UI: 启用或禁用 UI 功能。

输入信息后,配置文件 config.json 将生成在 [source/infrastructure/bin]目录中。您可以重新运行 npm run config 命令或修改此文件以自定义解决方案配置。

步骤 5: 准备所需的部署资源,包括前端和模型资产

npm run build

步骤 6: (可选)在目标账户和区域上引导 AWS CDK

如果这是您的账户首次使用 CDK 部署资源,请参考此文档进行 CDK bootstrap。

npx cdk bootstrap aws://<Your AWS account ID>/<AWS region>

步骤 7: 部署解决方案

npx cdk deploy

步骤 8: 确认部署

部署后,您可以在 CloudFormation 控制台中找到包含 intelli-agent 的堆栈。在堆栈的 Output 标签页中,您可以找到关键的解决方案信息,常用的信息解释如下:

名称 描述
WebPortalURL Intelli-Agent 前端网站链接。
APIEndpointAddress RESTful API 地址,主要用于数据预处理、聊天记录等功能。
WebSocketEndpointAddress WebSocket API 地址,主要用于聊天功能。

更新已有的部署

步骤 1: 进入 source/infrastructure 目录

cd Intelli-Agent/source/infrastructure

步骤 2: 更新解决方案配置

重新运行 npm run config 命令,或者直接修改source/infrastructure/bin 路径下的 config.json 文件以更新解决方案配置。

样本配置文件如下:

{
  "prefix": "",
  "email": "[email protected]",
  "deployRegion": "us-east-1",
  "knowledgeBase": {
    "enabled": false,
    "knowledgeBaseType": {
      "intelliAgentKb": {
        "enabled": true,
        "email": "[email protected]",
        "vectorStore": {
          "opensearch": {
            "enabled": true,
            "useCustomDomain": false,
            "customDomainEndpoint": ""
          }
        },
        "knowledgeBaseModel": {
          "enabled": true,
          "ecrRepository": "intelli-agent-knowledge-base",
          "ecrImageTag": "latest"
        }
      }
    }
  },
  "chat": {
    "enabled": true,
    "bedrockRegion": "us-east-1",
    "useOpenSourceLLM": true,
    "amazonConnect": {
      "enabled": true
    }
  },
  "model": {
    "embeddingsModels": [
      {
        "provider": "sagemaker",
        "name": "bce-embedding-and-bge-reranker",
        "commitId": "43972580a35ceacacd31b95b9f430f695d07dde9",
        "dimensions": 1024,
        "default": true
      }
    ],
    "llms": [
      {
        "provider": "bedrock",
        "name": "anthropic.claude-3-sonnet-20240229-v1:0"
      }
    ],
    "modelConfig": {
      "modelAssetsBucket": "intelli-agent-models-078604973627-us-west-2"
    }
  },
  "ui": {
    "enabled": true
  },
  "federatedAuth": {
    "enabled": true,
    "provider": {
      "cognito": {
        "enabled": true
      },
      "authing": {
        "enabled": false
      }
    }
  }
}

步骤 3: (可选) 如果需要添加新的SageMaker模型,或者需要更新前端资源,您需要重新运行 npm run build 命令来构建新的资源。

npm run build

步骤 4: 更新已有的部署

aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws
npx cdk deploy

卸载解决方案

登录 AWS 控制台,进入到 CloudFormation 页面,选择包含intelli-agent关键字的堆栈,点击删除按钮。

功能介绍

Portal

1 大语言模型切换

目前支持LLM如下:

  • Claude3 Haiku
  • Claude3 Sonnet
  • Claude3.5 Sonnet

2 聊天窗口

聊天区域由两个功能组成:聊天机器人和历史记录。 聊天机器人可以即时开启一段新的基于支持的LLM模型的对话。 历史记录 -> 需要重启的聊天记录ID,页面即会展示出过去的历史记录。用户可以在此基础上继续对话。

KB

3 文档库(知识库)

目前文档库(即RAG所需的知识库)支持基于文档的创建(一次上传一个)、删除(一次可删除多个)。

  • 支持文档格式(12种):pdf, docx, txt, csv, jsonl, json, html, md, png, jpg, jpeg, webp
  • UI上传文档大小限制:10MB

提示:

  • 如果用户重复上传了同名的文档,后台将会用最新的文档进行覆盖。
  • 创建文档 -> 选择文件并点击上传后,后台操作分两部分:文档上传和离线处理。全部完成后才会在状态栏展示完成
  • 示例: KB

4 用户管理

右上角显示当前用户名。点击退出登录即可退出。

5 界面展示语种切换

目前支持简体中文和英文。

API调用

在 CDK 部署后,您可以使用 HTTP client,例如 Postman/cURL 来调取 API.

FAQ

目前各处理环节的模型选型是什么

目前各环节使用的模型如下,是团队内部测试后、选用的当下效果比较理想的选项。支持客户自定义更换。详细模型更换。

Function Model
Rerank BGE-reranker-large
Embedding BCE
LLM Claude3/Claude3.5

如何获取支持

通过在 GitHub 上创建 Issue 获取支持。

部署后,如何获取初始用户名和密码

在CDK部署时您指定了SubEmail参数,它是用于接受邮件通知的邮箱地址,当CDK部署成功后,初始用户名和密码会发送到此邮箱。

如何切分文档

各种类型的文档首先会转换成Markdown格式,然后根据段落进行切分,如果切分后的段落超过最大token(默认值500,用户可以在glue-job-script.py中自定义),则进行二次切分,切分后的文本块和元数据会记录在S3桶中,在向量化后最终注入向量数据库。

如何注入意图数据

  • 根据文档获取jwt token,并参考postman使用的方式。
  • 根据文档进行注入。注入参数可以参考下面的格式,替换其中S3相关参数即可。
{
    "s3Bucket": "your-bucket-name",
    "s3Prefix": "s3path/default-intent.jsonl",
    "offline": "true",
    "qaEnhance": "false",
    "workspaceId": "default-intent",
    "operationType": "create",
    "documentLanguage": "zh",
    "indexType": "qq"
}
  • 注入数据格式
{"question": "你好", "answer": {"intent": "chat"}}

如何更新ETL使用的资源

目前方案在持续更新当中,对于文档解析部分更新需要手动进行

  1. [可选] 更新文档解析模型Endpoint
# 在执行sh build.sh时输入一个新的ETL tag
cd source/script
sh build.sh -b <S3 bucket name> -i <ETL model name> -t <new ETL tag name> -r <AWS region>

# 在执行cdk deploy时输入一个新的ETL tag,触发ETL endpoint的更新
npx cdk deploy --rollback true --parameters S3ModelAssets=<Your S3 Bucket Name> --parameters SubEmail=<Your email address> --parameters EtlImageName=<Your ETL model name> --parameters ETLTag=<Your new ETL tag name> --require-approval never
  1. 手动更新一下ETL依赖的whl包,需要先确认一下ETL Job中--extra-py-files对应的路径

Glue S3 bucket

然后将source/lambda/job/dep/dist/llm_bot_dep-0.1.0-py3-none-any.whl 上传到Glue依赖的位置

aws s3 cp source/lambda/job/dep/dist/llm_bot_dep-0.1.0-py3-none-any.whl s3://<Your Glue job bucket>/llm_bot_dep-0.1.0-py3-none-any.whl

测试

参考测试文档获取更多测试信息。

贡献

参考贡献文档获取更多信息。

License

此项目采用 Apache-2.0 License。