当前位置: 首页 > news >正文

从零开始部署Dify:后端与前端服务完整指南

从零开始部署Dify:后端与前端服务完整指南

    • 一、环境准备
      • 1. 系统要求
      • 2. 项目结构
    • 二、后端服务部署
      • 1. 中间件启动(Docker Compose)
      • 2. 后端环境配置
      • 3. 依赖安装与数据库迁移
      • 4. 服务启动
    • 三、前端界面搭建
      • 1. 环境配置
      • 2. 服务启动
    • 四、常见问题排查
    • 五、总结

在AI应用开发中,Dify作为一款功能强大的工具,其部署过程涉及多个技术栈的整合。本文将详细讲解如何从零开始搭建Dify的完整环境,包括后端服务和前端界面的配置与启动。


一、环境准备

1. 系统要求

  • 操作系统:Windows Subsystem for Linux (WSL) 或 Ubuntu 22.04+
  • Docker:版本24.0+
  • Python:3.12(通过Poetry管理)
  • Node.js:v18.x LTS(NPM/Yarn)

2. 项目结构

dify/
├── docker/
│   ├── docker-compose.middleware.yaml
│   └── middleware.env
├── api/
│   ├── .env
│   └── requirements.txt
└── web/├── package.json└── .env.local

二、后端服务部署

1. 中间件启动(Docker Compose)

# 进入docker目录
cd ../docker# 复制环境变量模板
cp middleware.env.example middleware.env# 启动Weaviate配置的中间件栈
docker compose -f docker-compose.middleware.yaml \--profile weaviate \-p dify \up -d

注意:在WSL环境中,不能使用/mnt路径,否则dify-db-1容器报错initdb: error: could not change permissions of directory "/var/lib/postgresql/data/pgdata": Operation not permitted,无法启动。

2. 后端环境配置

# 进入API目录
cd ../api# 生成随机密钥
sed -i "/^SECRET_KEY=/c\SECRET_KEY=$(openssl rand -base64 42)" .env

3. 依赖安装与数据库迁移

# 激活Poetry环境
poetry env use 3.12
poetry lock
poetry install# 数据库迁移
poetry run python -m flask db upgrade

4. 服务启动

# 后台启动API服务
poetry run python -m flask run \--host 0.0.0.0 \--port=5001 \--debug# 启动Celery异步任务队列
poetry run python -m celery \-A app.celery worker \-P gevent \-c 1 \--loglevel INFO \-Q dataset,generation,mail,ops_trace,app_deletion

三、前端界面搭建

1. 环境配置

# 安装Node.js依赖
npm install# 配置环境变量
cp .env.example .env.local# 示例配置(根据实际环境调整)
NEXT_PUBLIC_API_PREFIX=http://localhost:5001/console/api
NEXT_PUBLIC_PUBLIC_API_PREFIX=http://localhost:5001/api

2. 服务启动

# 开发模式启动
npm run dev# 访问地址
http://localhost:3000

四、常见问题排查

  1. 端口冲突:检查50013000端口是否被占用
  2. 环境变量错误:确保.env文件无语法错误

五、总结

通过以上步骤,我们成功搭建了Dify的完整运行环境。后端服务负责数据处理与存储,前端界面提供直观的操作界面。


参考文档:

  • Dify Backend API
  • Dify Frontend
http://www.lryc.cn/news/530920.html

相关文章:

  • springboot中路径默认配置与重定向/转发所存在的域对象
  • 二叉树——429,515,116
  • Leetcode 3444. Minimum Increments for Target Multiples in an Array
  • 分享半导体Fab 缺陷查看系统,平替klarity defect系统
  • Java基础——分层解耦——IOC和DI入门
  • DeepSeek-R1 本地部署教程(超简版)
  • Vue3学习笔记-模板语法和属性绑定-2
  • csapp笔记3.6节——控制(1)
  • PYH与MAC的桥梁MII/MIIM
  • 国内flutter环境部署(记录篇)
  • 选择排序_75. 颜色分类
  • C++ Primer 标准库vector
  • C# 数组和列表的基本知识及 LINQ 查询
  • 大厂面试题备份20250201
  • w191教师工作量管理系统的设计与实现
  • Git 版本控制:基础介绍与常用操作
  • 讲清逻辑回归算法,剖析其作为广义线性模型的原因
  • 数据结构(1)——算法时间复杂度与空间复杂度
  • K8s运维管理平台 - xkube体验:功能较多
  • spring源码阅读系列文章目录
  • 快速提升网站收录:利用网站新闻发布功能
  • 【14】WLC3504 HA配置实例
  • 什么是LPU?会打破全球算力市场格局吗?
  • 智慧物业管理系统实现社区管理智能化提升居民生活体验与满意度
  • Vue3 表单:全面解析与最佳实践
  • MySQl的日期时间加
  • 实战:如何利用网站日志诊断并解决收录问题?
  • 每日一题——有效括号序列
  • PyTorch数据建模
  • OpenAI 实战进阶教程 - 第二节:生成与解析结构化数据:从文本到表格