Agent 策略插件
Agent 策略插件能够帮助 LLM 执行推理或决策逻辑,包括工具选择、调用和结果处理,以更加自动化的方式处理问题。
本文将演示如何创建一个具备工具调用(Function Calling)能力,自动获取当前准确时间的插件。
前置准备
Dify 插件脚手架工具
Python 环境,版本号 ≥ 3.12
关于如何准备插件开发的脚手架工具,详细说明请参考初始化开发工具。
1. 初始化插件模板
运行以下命令,初始化 Agent 插件开发模板。
dify plugin init按照页面提示,填写对应信息。参考以下代码中的备注信息,进行设置。
➜ ./dify-plugin-darwin-arm64 plugin init ─╯
Edit profile of the plugin
Plugin name (press Enter to next step): # 填写插件的名称
Author (press Enter to next step): # 填写插件作者
Description (press Enter to next step): # 填写插件的描述
---
Select the language you want to use for plugin development, and press Enter to continue,
BTW, you need Python 3.12+ to develop the Plugin if you choose Python.
-> python # 选择 Python 环境
go (not supported yet)
---
Based on the ability you want to extend, we have divided the Plugin into four types: Tool, Model, Extension, and Agent Strategy.
- Tool: It's a tool provider, but not only limited to tools, you can implement an endpoint there, for example, you need both Sending Message and Receiving Message if you are
- Model: Just a model provider, extending others is not allowed.
- Extension: Other times, you may only need a simple http service to extend the functionalities, Extension is the right choice for you.
- Agent Strategy: Implement your own logics here, just by focusing on Agent itself
What's more, we have provided the template for you, you can choose one of them below:
tool
-> agent-strategy # 选择 Agent 策略模板
llm
text-embedding
---
Configure the permissions of the plugin, use up and down to navigate, tab to select, after selection, press enter to finish
Backwards Invocation:
Tools:
Enabled: [✔] You can invoke tools inside Dify if it's enabled # 默认开启
Models:
Enabled: [✔] You can invoke models inside Dify if it's enabled # 默认开启
LLM: [✔] You can invoke LLM models inside Dify if it's enabled # 默认开启
→ Text Embedding: [✘] You can invoke text embedding models inside Dify if it's enabled
Rerank: [✘] You can invoke rerank models inside Dify if it's enabled
TTS: [✘] You can invoke TTS models inside Dify if it's enabled
Speech2Text: [✘] You can invoke speech2text models inside Dify if it's enabled
Moderation: [✘] You can invoke moderation models inside Dify if it's enabled
Apps:
Enabled: [✘] Ability to invoke apps like BasicChat/ChatFlow/Agent/Workflow etc.
Resources:
Storage:
Enabled: [✘] Persistence storage for the plugin
Size: N/A The maximum size of the storage
Endpoints:
Enabled: [✘] Ability to register endpoints初始化插件模板后将生成一个代码文件夹,包含插件开发过程中所需的完整资源。熟悉 Agent 策略插件的整体代码结构有助于插件的开发过程。
插件的功能代码集中在 strategies/ 目录内。
2. 开发插件功能
Agent 策略插件的开发主要围绕以下两个文件展开:
插件声明文件:
strategies/basic_agent.yaml插件功能代码:
strategies/basic_agent.py
2.1 定义参数
要创建一个 Agent 插件,首先需要在 strategies/basic_agent.yaml 文件中定义插件所需的参数。这些参数决定了插件的核心功能,例如调用 LLM 模型和使用工具的能力。
建议优先配置以下四个基础参数:
1. model:指定要调用的大语言模型(LLM),如 GPT-4、GPT-4o-mini 等。
2. tools:定义插件可以使用的工具列表,增强插件功能。
3. query:设置与模型交互的提示词或输入内容。
4. maximum_iterations:限制插件执行的最大迭代次数,避免过度计算。
示例代码:
完成参数配置后,插件将在自动生成相应的设置的使用页面,方便你进行直观、便捷的调整和使用。

2.2 获取参数并执行
当使用者在插件的使用页面完成基础的信息填写后,插件需要处理已填写的传入参数。因此需要先在 strategies/basic_agent.py 文件内定义 Agent 参数类供后续使用。
校验传入参数:
获取参数后,执行具体的业务逻辑:
2.3 调用模型
在 Agent 策略插件中,调用模型是核心执行逻辑之一。可以通过 SDK 提供的 session.model.llm.invoke() 方法高效地调用 LLM 模型,实现文本生成、对话处理等功能。
如果希望模型具备调用工具的能力,首先需要确保模型能够输出符合工具调用格式的输入参数。也就是说,模型需要根据用户指令生成符合工具接口要求的参数。
构造以下参数:
model:模型信息
prompt_messages:提示词
tools:工具信息(Function Calling 相关)
stop:停止符
stream:是否支持流式输出
方法定义示例代码:
要查看完整的功能实现,请参考模型调用示例代码。
该代码实现了以下功能:用户输入指令后,Agent 策略插件会自动调用 LLM,根据生成结果构建并传递工具调用所需的参数,使模型能够灵活调度已接入的工具,高效完成复杂任务。

2.4 为模型添加记忆
当使用 Agent 插件调用模型时,为模型添加记忆功能能够极大提升对话体验。通过记忆功能,模型可以理解完整的对话上下文,实现连贯的交互体验和精准的工具调用。
具体实现步骤:
配置记忆功能
在 Agent 插件的 YAML 配置文件 strategies/agent.yaml 中添加 history-messages 特性:
启用记忆设置
修改插件配置文件并重启后,你将在节点配置界面中看到 记忆 开关。点击右侧的开关按钮,启用记忆功能。

启用后,您可以通过 窗口大小 滑块调整记忆窗口,它决定了模型能够“记住”多少之前的对话内容。
调试历史消息
添加以下代码,查看历史消息内容:

控制台将显示类似如下输出:
将历史消息集成到模型调用
最后,修改模型调用代码,将历史消息拼接到当前查询:
效果验证
添加加记忆功能后,模型能够基于历史对话进行回复。在下图示例中,模型成功地记住了之前对话中提及的用户名称,实现了对话的连贯性。

2.5 调用工具
填写工具参数后,需赋予 Agent 策略插件实际调用工具的能力。可以通过 SDK 中的session.tool.invoke() 函数进行工具调用。
构造以下参数:
provider:工具提供商
tool_name:工具名称
parameters:输入参数
方法定义示例代码:
若希望通过 LLM 直接生成参数完成工具调用,请参考以下工具调用的示例代码:
如需查看完整的功能代码,请阅读调用工具示例代码。
实现这部分的功能代码后,Agent 策略插件将具备自动 Function Calling 的能力,例如自动获取当前时间:

2.6 日志创建
在 Agent 策略插件中,通常需要执行多轮操作才能完成复杂任务。记录每轮操作的执行结果对于开发者来说非常重要,有助于追踪 Agent 的执行过程、分析每一步的决策依据,从而更好地评估和优化策略效果。
为了实现这一功能,可以利用 SDK 中的 create_log_message 和 finish_log_message 方法记录日志。这种方式不仅可以在模型调用前后实时记录操作状态,还能帮助开发者快速定位问题。
场景示例:
在模型调用之前,记录一条“开始调用模型”的日志,帮助开发者明确任务执行进度。
在模型调用成功后,记录一条“调用成功”的日志,方便追踪模型响应的完整性。
设置完成后,工作流日志将输出执行结果:

在 Agent 执行的过程中,有可能会产生多轮日志。若日志能具备层级结构将有助于开发者查看。通过在日志记录时传入 parent 参数,不同轮次的日志可以形成上下级关系,使日志展示更加清晰、易于追踪。
引用方法:
插件功能示例代码
调用模型
以下代码将演示如何赋予 Agent 策略插件调用模型的能力:
调用工具
以下代码展示了如何为 Agent 策略插件实现模型调用并向工具发送规范化请求。
完整功能代码示例
包含调用模型、调用工具以及输出多轮日志功能的完整插件代码示例:
3. 调试插件
配置插件的声明文件与功能代码后,在插件的目录内运行 python -m main 命令重启插件。接下来需测试插件是否可以正常运行。Dify 提供远程调试方式,前往“插件管理”获取调试 Key 和远程服务器地址。

回到插件项目,拷贝 .env.example 文件并重命名为 .env,将获取的远程服务器地址和调试 Key 等信息填入至 REMOTE_INSTALL_HOST 与 REMOTE_INSTALL_KEY 参数内。
运行 python -m main 命令启动插件。在插件页即可看到该插件已被安装至 Workspace 内。其他团队成员也可以访问该插件。

打包插件(可选)
确认插件能够正常运行后,可以通过以下命令行工具打包并命名插件。运行以后你可以在当前文件夹发现 google.difypkg 文件,该文件为最终的插件包。
恭喜,你已完成一个工具类型插件的完整开发、调试与打包过程!
发布插件(可选)
现在可以将它上传至 Dify Plugins 代码仓库来发布你的插件了!上传前,请确保插件已遵循插件发布规范。审核通过后,代码将合并至主分支并自动上线至 Dify Marketplace。
探索更多
复杂任务往往需要多轮思考和多次工具调用。为了实现更智能的任务处理,通常采用循环执行的策略:模型调用 → 工具调用,直到任务完成或达到设定的最大迭代次数。
在这个过程中,提示词(Prompt)管理变得尤为重要。为了高效地组织和动态调整模型输入,建议参考插件内 Function Calling 功能的完整实现代码,了解如何通过标准化的方式来让模型调用外部工具并处理返回结果。
Last updated