微信扫码
添加专属顾问
我要投稿
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.gz
cd 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=localhost
DB_PORT=3306
DB_USER=root
DB_PASSWD=root
DB_NAME=testdb
# MCP服务
# service
MCP_HOST=0.0.0.0
MCP_PORT=8000
# 两个mcp工具:get_table_definition: 获取表结构定义 和 execute_sql: 执行SQL语句
import mysql.connector
import json
import os
from contextlib import contextmanager
from dotenv import load_dotenv
from 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"), # 数据库名
)
@contextmanager
def get_cursor(self):
with self.connection_pool.get_connection() as connection:
cursor = None
try:
cursor = connection.cursor()
yield cursor
connection.commit()
except Exception as e:
connection.rollback()
raise e
finally:
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 server
mcp = 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 server
mcp.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-08-19
【万字长文】Dify 知识库全链路图解:7 个关键节点,彻底拆解 RAG 黑盒
2025-08-18
Dify功能解析四:Dify父子模式分段解决普通分段的什么问题?
2025-08-17
Dify 实战篇| 配置参数实战优化
2025-08-17
MacBook 本地化部署 Dify 指南。
2025-08-15
4000字长文:使用dify搭建SOP检索问答Agent
2025-08-14
效率与安全双飞跃!Dify v1.7.2 上线:全新升级工作流关系面板、节点搜索、API 版本指定与多项安全优化,支持一键部署
2025-08-13
Dify v1.7.2版本更新:工作流可视化和节点搜索,让你更加快捷地玩转工作流!
2025-08-13
Dify结合Minio文件解析生成思维导图
2025-06-04
2025-06-25
2025-06-03
2025-05-29
2025-06-02
2025-06-29
2025-06-24
2025-05-22
2025-06-05
2025-06-10
2025-08-18
2025-08-02
2025-07-30
2025-06-26
2025-06-17
2025-05-29
2025-05-28
2025-05-22