微信扫码
添加专属顾问
我要投稿
5分钟快速上手Dify,零代码打造你的专属AI应用,从聊天机器人到智能工作流一应俱全。 核心内容: 1. Dify平台的核心功能与特色亮点 2. 社区版Dify的安装部署指南 3. 支持构建的多种AI应用类型解析
一、概述
1、简介
dify 是一个开源的 LLM 应用程序开发平台。其直观的界面结合了代理 AI 工作流、RAG 管道、代理功能、模型管理、可观察性功能等,使您能够快速从原型过渡到生产。
2、特点
工作流程: 在可视化画布上构建和测试强大的 AI 工作流,利用以下所有功能及其他功能。
全面的模型支持: 与来自数十个推理提供商和自托管解决方案的数百个专有/开源 LLM 无缝集成,涵盖 GPT、Mistral、Llama3 和任何与 OpenAI API 兼容的模型。
提示 IDE: 直观的界面,用于制作提示、比较模型性能以及向基于聊天的应用程序添加其他功能,例如文本转语音。
RAG 管道: 广泛的 RAG 功能,涵盖从文档摄取到检索的所有内容,并为从 PDF、PPT 和其他常见文档格式中提取文本提供开箱即用的支持。
代理能力: 您可以根据 LLM Function Calling 或 ReAct 定义代理,并为代理添加预构建或自定义工具。Dify 为 AI 代理提供了 50+ 内置工具,例如 Google 搜索、DALL·E、稳定扩散和 WolframAlpha。
LLMOps: 监控和分析一段时间内的应用程序日志和性能。您可以根据生产数据和注释不断改进提示、数据集和模型。
后端即服务: Dify 的所有产品都带有相应的 API,因此您可以毫不费力地将 Dify 集成到您自己的业务逻辑中。
3、支持的智能应用程序类型
聊天助手:构建基于LLM的对话机器人
Agent:能够进行任务分解、推理和工具调用的对话式智能助手.
Text Generator(文本生成应用):文本生成任务的助手,例如编写故事、文本分类、翻译等。
Chatflow:具有内存能力的多轮复杂对话任务的工作流编排.
workflow(工作流):用于自动化和批处理等单轮任务的工作流编排。
二、社区版Dify搭建
1、系统要求:最低2核4G的配置
2、下载源码,docker方式启动
# git地址https://github.com/langgenius/dify/archive/refs/tags/1.4.0.tar.gz
3、使用dockers方式启动
# 默认基础tar -xf dify-1.4.0.tar.gzcd dify-1.4.0/docker/cp .env.example .env# 启动服务## 检测compose版本docker compose version# 使用 Docker Compose V2启动服务docker compose up -d
# docker-compose.yaml 和 .env.example文件官方地址:https://docs.dify.ai/en/getting-started/install-self-hosted/environments
# 初始化设置账号密码http://your_server_ip/install
1、基本MySQL5.7创建表配置
create database testdb;use testdb;CREATE TABLE `finance` (`id` bigint(20) NOT NULL AUTO_INCREMENT,`user_id` varchar(36) NOT NULL DEFAULT '' COMMENT '用户ID',`date` datetime NOT NULL COMMENT '金额发生日期',`amount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '收入支出金额(收入记为正数,支出记为负数)',`category` varchar(32) NOT NULL DEFAULT '' COMMENT '收支类别',`remark` varchar(100) NOT NULL DEFAULT '' COMMENT '收支具体类目',PRIMARY KEY (`id`),KEY `idx_user_date` (`user_id`,`date`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='日常收支';
# mysql配置DB_HOST=localhostDB_PORT=3306DB_USER=rootDB_PASSWD=rootDB_NAME=testdb# MCP服务# serviceMCP_HOST=0.0.0.0MCP_PORT=8000
# 两个mcp工具:get_table_definition: 获取表结构定义 和 execute_sql: 执行SQL语句import mysql.connectorimport jsonimport osfrom contextlib import contextmanagerfrom dotenv import load_dotenvfrom mcp.server.fastmcp import FastMCP# 加载环境变量load_dotenv()class DbManager:def __init__(self):self.connection_pool = mysql.connector.pooling.MySQLConnectionPool(pool_name="db_pool",pool_size=5,pool_reset_session=True,host=os.getenv("DB_HOST"), # 数据库服务器地址port=os.getenv("DB_PORT"),user=os.getenv("DB_USER"), # 数据库用户名password=os.getenv("DB_PASSWD"), # 数据库密码database=os.getenv("DB_NAME"), # 数据库名)@contextmanagerdef get_cursor(self):with self.connection_pool.get_connection() as connection:cursor = Nonetry:cursor = connection.cursor()yield cursorconnection.commit()except Exception as e:connection.rollback()raise efinally:if cursor:cursor.close()def execute_sql(self, sql: str) -> str:with self.get_cursor() as cursor:cursor.execute(sql)if cursor.description is not None:rows = cursor.fetchall()result = {"columns": [desc[0] for desc in cursor.description],"rows": rows,}return json.dumps(result, default=str)else:return f"row affected:{cursor.rowcount}"dbManager = DbManager()# Initialize FastMCP servermcp = FastMCP(host=os.getenv("MCP_HOST", "127.0.0.1"), port=int(os.getenv("MCP_PORT", 8000)))def get_table_definition(table: str) -> str:"""get table definition"""return dbManager.execute_sql(f"show create table {table}")def execute_sql(sql: str) -> str:"""execute sql"""return dbManager.execute_sql(sql)if __name__ == "__main__":# Initialize and run the servermcp.run(transport="sse")
#启动服务接口
点击右上角“插件”按钮,进入插件页面,选择“探索Marketplace“选择插件"Dify Agent 策略"和"MCP SSE / StreamableHTTP" 两个插件安装。
切换到"插件"tab,选择已经安装的插件"MCP SSE / StreamableHTTP",点击“去授权”
# 配置MCP Service服务接口{ "server_name": { "url": "http://192.168.165.65:8001/sse", "headers": {}, "timeout": 50, "sse_read_timeout": 50 }}创建一个空白应用,类型为Chatflow
调整工作流,把默认的LLM节点替换为Agent节点
设置Agent节点的Agent策略,并添加MCP工具:策略选择Function Calling,选择模型,设置工具列表(获取和调用MCP工具),指令等待。
角色你是记账助手,可以通过调用MCP工具完成记录日常收入和支出并作分析。为了获得MCP工具列表,必须先通过mcp_sse_list_tools获取。为了完成记账操作,需要先获取表finance的定义。记账的用户ID取值为{{#sys.user_id#}}# 收支类别收入:工资薪金,劳务报酬,投资收益,分红收入,租金收入,其它收入支出:住房,交通,通讯,保险,餐饮,电子产品,日用品,服饰,旅行,娱乐,医疗,学习,其它支出# 技能# 技能1:记录日常开支将开支信息记录到数据库表finance## 技能2:统计日常开支根据用户输入信息分析统计日常开支# 限制仅处理记账相关问题,不回复其它问题
设置Agent节点的查询和最大迭代次数,Agent完成一项任务可能需要迭代多次调用工具,最大迭代次数设置过小可能导致无法正常完成任务。
下一节点添加”直接回复“,回复变量”agent{x}test“即可
5、发布后,验证即可
输入“昨天吃饭用了50元,还花了22元买了拖鞋。今天买手机花了1999元,吃饭花了60元”,验证输出为成功记录支出。
展示效果:
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业
2025-10-30
Dify流程暂停与人工干预:3种实现方案+避坑指南
2025-10-16
告别升级噩梦:Dify 二次开发的无缝适配策略与实战案例(基于 v1.9.1)
2025-10-13
用Dify搭建企业知识库:5个实战技巧提升检索准确率90%
2025-10-13
Dify接口调用实战指南:从入门到精通的避坑手册,收藏了!
2025-10-12
Dify1.6.0升级1.9.1步骤及踩坑记
2025-10-10
用 Dify 零代码搭建 AI 用研助理,5分钟完成100个虚拟用户调研
2025-09-30
重大消息,刚刚Dify 1.9.1发布了!我们聊聊带来了哪些吸引人的功能特性?
2025-09-26
内网环境下Dify1.9.0版本镜像构建过程记录
2025-10-13
2025-09-03
2025-09-16
2025-09-06
2025-08-19
2025-09-23
2025-09-02
2025-08-18
2025-09-04
2025-10-12
2025-09-30
2025-09-23
2025-09-06
2025-09-05
2025-08-29
2025-08-18
2025-08-02
2025-07-30