百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

【ai】dify+python开发AI八字排盘插件

off999 2025-07-21 17:07 54 浏览 0 评论

Dify 插件是什么?

你可以将 Dify 插件想象成赋予 AI 应用增强感知和执行能力的模块化组件。它们使得将外部服务、自定义功能以及专用工具以”即插即用”的简洁方式集成到基于 Dify 构建的 AI 应用中成为可能。通过插件,你的 AI 应用可以更好地”看”、“听”、“说”、“画”、“计算”、“推理”,连接外部 API,甚至执行真实世界的操作。

为什么选择开发 Dify 插件?

扩展 AI 能力: 为基于 Dify 的应用赋予专业工具、多模态处理、连接现实世界服务等无限可能。

定制化 Dify 体验: 通过构建专属插件,精准满足特定业务场景或工作流的需求。

重塑智能流程: 利用自定义工具和 Agent 策略,优化 RAG 流程、增强 Agent 推理能力。

实现模块化与解耦: 将功能作为独立的插件进行开发和管理,提高代码的可维护性和灵活性。

享受开发者友好体验: 我们提供强大的 SDK、便捷的远程调试工具和清晰的文档,助你高效开发。

AI 应用

Dify 插件是赋予 AI 应用增强感知和执行能力的模块化组件。可以将外部服务、自定义功能以及专用工具以”即插即用”的简洁方式集成到基于 Dify 构建的 AI 应用中。

dify支持的开发插件类型: 针对每种插件类型,提供专门的开发指南:

模型 (Models: 学习如何将不同的 AI 模型打包、配置并作为插件进行管理。

工具 (Tools): 为 Agent 和工作流构建专业能力,如数据分析、内容处理、自定义集成等。

Agent 策略 (Agent Strategies): 创建自定义的推理策略(如 ReAct, CoT, ToT)来赋能 Dify 中的自主 Agent。

扩展 (Extensions): 通过 HTTP Webhook 实现与外部服务的集成,处理复杂逻辑。

包 (Bundles): 了解如何将多个插件组合打包,以便于分发和部署


Dify 标准结构介绍

your_plugin/
├── _assets/             # 图标和视觉资源
├── provider/            # 提供者定义和验证
│   ├── your_plugin.py   # 凭证验证逻辑
│   └── your_plugin.yaml # 提供者配置
├── tools/               # 工具实现
│   ├── feature_one.py   # 工具功能实现
│   ├── feature_one.yaml # 工具参数和描述
│   ├── feature_two.py   # 另一个工具实现
│   └── feature_two.yaml # 另一个工具配置
├── utils/               # 辅助函数
│   └── helpers.py       # 通用功能逻辑
├── working/             # 进度记录和工作文件
├── .env.example         # 环境变量模板
├── main.py              # 入口文件
├── manifest.yaml        # 插件主配置
├── README.md            # 文档
└── requirements.txt     # 依赖列表
  • main.py 整个项目的入口文件manifest.yaml 整个插件的基础配置文件
    • 插件描述
    • resource所需资源(权限、内存)
    • plugins 指向provider
    • meta 支持的架构、python版本、隐私协议,仓库地址等
  • provider 插件描述
    • your_plugin.py 验证这个插件的依赖、环境、资源等
    • your_plugin.yaml 描述了这个插件是干什么的,有哪些工具,这个是dify查找工具的入口
  • tools 工具的实现目录
    • 一个工具一组py和yaml
    • py为对应的工具的实现,需要符合dify的规范
    • yaml 有几个作用
      1. 识工具的唯一性identity
      2. description描述工具
      3. parameters 工具所需的参数
      4. extra 指定工具的实现python
  • requirements.txt包含所有依赖


  • 实现

    温馨提示:如果大家使用agent开发,比如cursor、codebuddy,可以直接使用官方的提示词。

    dify提供了一个dify-plugin-daemon 工具用于辅助开发,是一个脚手架,可以直接一步步的执行,生成框架。

    # 复制工具YAML文件作为模板
    cp tools/existing_tool.yaml tools/new_feature.yaml
    # 复制工具Python实现
    cp tools/existing_tool.py tools/new_feature.py
    • 更新YAML中的名称、描述和参数
    • 更新Python文件中的类名和实现逻辑
    • 确保每个文件只包含一个Tool子类

    在provider/your_plugin.yaml中添加新工具:

    tools:
      - tools/existing_tool.yaml
      - tools/new_feature.yaml  # 添加新工具

    插件初始化

    1、执行 .\dify-plugin.exe plugin init

    2、填写插件名称、Author、和插件描述

    3、上下键选择插件类型,选中以后回车

    4、上下键选择权限,然后tab切换选中

    5、描述最小版本

    一路按提示操作,最后会生成基础版本的插件。

    调试

    在.env文件中修改REMOTE_INSTALL_URLREMOTE_INSTALL_KEY

    执行python -m main

    安装插件

    dify 的插件,默认是开启签名认证的。有两种方案:

    1、关闭签名验证

    在dify部署的.env中,搜索FORCE_VERIFYING_SIGNATURE,并改为false

    FORCE_VERIFYING_SIGNATURE=false
    //之后
    docker compose down
    docker compose up -d
    • 使用自签名(只能在开源版本中使用,官方是单独的一套)

    执行下面的命令,-f 后面为插件名。

    .\dify-plugin.exe signature generate -f wuyunliuqi

    生成公钥和私钥对

    o wuyunliuqi.private.pem 私钥,用来加签名

    o wuyunliuqi.public.pem 公钥,用来验签名

    # 先打包 会打包出来一个wuyunliuqi.difypkg 文件
    .\dify-plugin.exe plugin package .\wuyunliuqi
    
    # 加签,使用指定的签名对wuyunliuqi.difypkg 进行加签,
    .\dify-plugin.exe signature sign wuyunliuqi.difypkg -p wuyunliuqi.private.pem

    修改docker-compose文件,在plugin_daemon中添加公钥

    plugin_daemon:  
    image:langgenius/dify-plugin-daemon:0.1.2-local
    restart:always
    environment:
        THIRD_PARTY_SIGNATURE_VERIFICATION_ENABLED:true
        THIRD_PARTY_SIGNATURE_VERIFICATION_PUBLIC_KEYS: /app/storage/public_keys/wuyunliuqi_key.public.pem

    这种自签名比较适合,有源码,有多个插件,都可以用这对公私钥进行加签验签。

    插件应用

    1、添加节点的时候,直接选择工具

    2、找到自己开发的插件,然后添加插件进去

    3、设置对应的变量即可


    常见错误排查

    当遇到Multiple subclasses of Tool错误时:

    1. 检查问题文件
    • 寻找形如class AnotherTool(Tool):的额外类定义
    • 确保文件中只有一个继承自Tool的类
    • 例如:如果encrypt.py包含EncryptTool和DecryptTool,保留EncryptTool并将DecryptTool移至decrypt.py
    1. 检查导入错误
    • 确认导入的函数名或类名是否拼写正确
    • 注意下划线、大小写等细节
    • 修正导入语句中的拼写错误## 文件结构与代码组织规范


    当遇到xxx error for ToolProviderConfiguration错误时:

    出现该报错,直接看工具的yaml文件,根据提示,比如下面的报错,缺少identity和extra(这是用大模型生成的时候报的)

    ValueError: Error loading plugin configuration: 3 validation errors for ToolProviderConfiguration
    identity.description - Field required
    identity.icon - Field required  
    extra - Field required
    


    当遇到Failed to parse response from plugin daemon to PluginDaemonBasicResponse [PluginToolProviderEntity]错误时:

    PS:装完插件所有插件都不能用了

    缺少了main.py文件。每个Dify插件都必须有这个入口文件:

    from dify_plugin import Plugin, DifyPluginEnv  
      
    plugin = Plugin(DifyPluginEnv(MAX_REQUEST_TIMEOUT=120))  
      
    if __name__ == '__main__':  
        plugin.run()  


    遇到invalid parameter type 'text-input'错误时:

    大模型在YAML里写的参数类型是text-input,但Dify框架不支持这个类型。

    • type (必填)参数类型,目前支持string、number、boolean、select、secret-input、file、files、model-selector、app-selector 九种类型,分别对应字符串、数字、布尔值、下拉框、加密输入框、文件、文件集、模型选择、应用选择,对于敏感信息,请使用 secret-input 类型。
    • form (必填)表单类型,目前支持llm、form两种类型,建议填写llm不要填写form


    总结

    Dify插件开发整体还算友好,但坑也不少……

    遇到问题时,优先查官方文档和示例代码(示例代码比较老旧),AI只能做参考,避免被带跑偏,走弯路浪费更多时间和精力。

    相关推荐

    阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

    TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

    高流量大并发Linux TCP性能调优_linux 高并发网络编程

    其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

    性能测试100集(12)性能指标资源使用率

    在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

    Linux 服务器常见的性能调优_linux高性能服务端编程

    一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

    Nginx性能优化实战:手把手教你提升10倍性能!

    关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...

    高并发场景下,Spring Cloud Gateway如何抗住百万QPS?

    关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...

    Kubernetes 高并发处理实战(可落地案例 + 源码)

    目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...

    高并发场景下,Nginx如何扛住千万级请求?

    Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...

    Spring Boot+Vue全栈开发实战,中文版高清PDF资源

    SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

    Docker-基础操作_docker基础实战教程二

    一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...

    你有空吗?跟我一起搭个服务器好不好?

    来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...

    部署你自己的 SaaS_saas如何部署

    部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...

    Docker Compose_dockercompose安装

    DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...

    京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统

    前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...

    Kubernetes (k8s) 入门学习指南_k8s kubeproxy

    Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...

    取消回复欢迎 发表评论: