Skip to content

Latest commit

 

History

History
150 lines (105 loc) · 7.81 KB

2.运行第一个教程案例.md

File metadata and controls

150 lines (105 loc) · 7.81 KB

运行第一个教程案例

通过本文档,您将了解到如何快速运行agentUniverse的示例,并亲身体验其效果。

1.准备工作

在正式运行示例案例之前,需要确保您安装了必要的运行环境与工程准备。若您已经完成环境配置请跳过该部分。

1.1 环境准备

agentUniverse支持 macoslinuxwindows3个系统平台,不同的系统平台环境配置细节会略有不同,这里我们不展开罗列,可以根据文档提供的必要步骤检查是否满足所有,并自行根据系统平台搜索对应软件配置教程。

1.1.1 python环境准备

使用 python 3.10 版本

Tips: 如果您的电脑已经安装其他python版本环境,强烈建议您使用conda等python环境管理工具隔离出不同的多版本python环境。

1.1.2 开发工具准备

agentUniverse是面向标准容器化交付的,包含标准镜像,您可以通过shell运行和修改源代码用于研发阶段,但是这种方式效率不高。

尽管本部分不是必须的,但是我们强烈建议您安装一个面向python的IDE工具。结合python的研发体验我们推荐使用pycharm,其次是vscode(vs面向python研发配置会麻烦些,不建议python研发初学者使用)。

不要忘了在对应的IDE工具配置python interpreter。

1.2 工程准备

1.2.1 样例工程准备

您可以在项目门户网页中或使用git clone下载agentUniverse源代码。

完成本部分操作您会获得如下的工程结构,其中源码中的examples/sample_standard_app文件夹为标准脚手架工程代码。 本文的后续案例运行将使用这个标准工程进行。

1.2.2 安装对应的框架包

# 框架包
pip install agentUniverse

# 产品可视化界面包(按需安装)
pip install magent-ui ruamel.yaml

1.2.3 密钥配置

本框架支持通过环境变量、文件配置等方式注入密钥,我们在密钥设置的单独章节会说明完整用法,这里我们展示文件配置密钥的步骤。请严格按顺序检查下列步骤是否满足:

step1. 确认config文件开启自动读取外置密钥文件

找到项目工程中的主配置文件(路径为:agentUniverse/examples/sample_standard_app/config/config.toml);找到 SUB_CONFIG_PATH 配置项下的 custom_key_path,如下图: config_ak_path

项目已经默认开启了这一能力,这个配置项将提供自动读取配置文件并批量加载密钥的能力,我们可以看到 custom_key_path 配置项已经默认包含了1个路径,为了简化教程在这里我们暂不修改路径。

step2. 根据模版创建外置密钥文件

外置密钥文件模版在config的同层级路径(具体路径为: agentUniverse/examples/sample_standard_app/config/custom_key.toml.sample),我们将 custom_key.toml.sample 拷贝并且创建一个新文件,结合step1中custom_key_path的默认配置命名将新文件命名为 custom_key.toml,如下图: config_ak_create_file

Tips: 外置密钥文件一般包含了您的所有ak,这是非常私密且需要严格保护的,这个文件是绝对不允许被泄漏或者被git这类代码平台管理的。在实际的生产项目中,我们通常会将该文件剥离出项目外,并且加上一个系统级别的强权限管控,本框架的密钥配置之所以会有这些步骤更多的是出于生产安全性的考虑。

step3. 在外置密钥文件中配置您的常用模型ak

密钥文件已包含了数十种常见的模型服务ak格式,你可以根据自身需求填写自己的密钥,别忘了放开注释。

后续的教程中,我们将以千问与GPT模型作为教程agent使用的llm,所以这里我们以千问、GPT为例配置对应的ak如下图: config_ak_demo_key

2. 运行第一个案例

sample_standard_app工程中已经包含了一个最基础的agent实例,其调用入口路径在: agentUniverse/examples/sample_standard_app/intelligence/test/demo_agent.py

在本节我们将其作为第一个运行的agent案例,我们选取 demo_agent 作为第一个教程案例。

2.1 确定example背后使用的agent与其配置

以 demo_agent案例 为例,我们在案例测试脚本中找到对应的agent_name为demo_agent。 demo_agent_case

确定example使用的agent后,我们到该项目的agent目录(目录路径为:agentUniverse/examples/sample_standard_app/intelligence/agentic/agent/agent_instance)下找到对应的agent配置 demo_agent.yaml,注意agent配置中的name项即为测试脚本中调用的agent名称 demo_agent_case_yaml

我们进一步查看 demo_agent.yaml 中的其他配置详情,在这里请进一步关注 llm_model 这一个配置项,这一项为配置选择agent所使用的llm,demo_agent 中默认使用了 demo_llm 这一模型实例作为agent的模型内核。我们进一步到该项目的llm目录(目录路径为:agentUniverse/examples/sample_standard_app/intelligence/agentic/llm)下找到对应的llm配置 demo_llm.yaml。

demo_llm_yaml

我们可以看到在demo_llm中使用了qwen2.5-72b-instruct模型。

切换模型

若您在密钥配置阶段配置的为其他系列模型类型可以在llm下创建对应的模型实例。aU已经为大家内置了常用的模型替换参考,如下。您可以复制并在demo_agent.yaml中的llm_model配置下替换,model_name有需要可以自行按照服务商官方模型code替换。

千问系列

  llm_model:
    name: 'default_qwen_llm'
    model_name: 'qwen-max'

gpt系列

  llm_model:
    name: 'default_openai_llm'
    model_name: 'gpt-4o'

文心系列

  llm_model:
    name: 'default_wenxin_llm'
    model_name: 'ERNIE-3.5-8K'

kimi系列

  llm_model:
    name: 'default_kimi_llm'
    model_name: 'moonshot-v1-8k'

百川系列

  llm_model:
    name: 'default_baichuan_llm'
    model_name: 'Baichuan2-Turbo'

DeepSeek系列

  llm_model:
    name: 'default_deepseek_llm'
    model_name: 'deepseek-chat'

Tips:为简化配置过程,这里我们只列举了部分常用模型服务,此外除了模型服务商、本地部署模型均可配置,我们在这个章节不演示,有这部分需求的用户可以进一步关注llm配置相关的章节。

切换工具

在本案例中demo_agent默认使用了 mock_search_tool 这个工具,为了方便大家体验这个工具默认模拟了样例问题"分析下巴菲特减持比亚迪的原因"所需涉及的搜索引擎返回结果。

您可以在 demo_agent.yaml 中切换使用真实的检索工具 demo_search_tool。 该工具将提供连网检索能力,为了体验用例我们建议您申请serper并提前在密钥部分内置搜索工具的ak,serper官方已经提供上千次的免费检索额度用于您的体验。

你需要在serper官网申请SERPER_API_KEY并配置,官网地址: https://serper.dev

申请完成后,在密钥配置步骤中提到的 custom_key.toml 中找到对应的key填写,并放开注释如下:

#Google search
SERPER_API_KEY='xxxxxx'

2.2 运行案例

通过上述的步骤,您已经完成了所有前置工作,让我们来直接运行看一看效果。找到agentUniverse/examples/sample_standard_app/intelligence/test/demo_agent.py文件,在ide或在shell中运行。

demo_agent_case_run

当你看到如下结果时说明案例已经跑通了。

demo_agent_case_run_result

3. 其他案例的运行

至此你已经完成了第一个案例的运行, 按照本章节的步骤执行您可以运行其他官方案例了。