开源 LLM 应用开发平台 Dify 全栈部署指南(Docker Compose 方案)

开源 LLM 应用开发平台 Dify 全栈部署指南(Docker Compose 方案)

一、部署环境要求与前置检查

1.1 硬件最低配置

组件 要求
CPU 双核及以上
内存 4GB 及以上
磁盘空间 20GB 可用空间

1.2 系统兼容性验证

  • ✅ 官方支持系统:
    • Ubuntu 20.04/22.04 LTS
    • Debian 11/12
  • ❗ 注意事项:
    • 推荐使用纯净系统环境
    • 避免与其他占用 80/443 端口的服务冲突

1.3 安装验证

部署成功查看:

浏览器访问:

二、容器化部署全流程

2.1 容器运行时安装

Docker 引擎部署
bash 复制代码
# 卸载旧版本(全新安装可跳过)
sudo apt-get remove docker docker-engine docker.io containerd runc

# 安装依赖工具集
sudo apt-get update && sudo apt-get install -y \
    ca-certificates \
    curl \
    gnupg \
    lsb-release

# 添加官方 GPG 密钥
sudo mkdir -m 0755 -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg

# 设置稳定版仓库
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

# 安装 Docker CE
sudo apt-get update && sudo apt-get install -y \
    docker-ce \
    docker-ce-cli \
    containerd.io \
    docker-buildx-plugin \
    docker-compose-plugin
Docker Compose 安装
bash 复制代码
# 获取最新稳定版(示例版本号可替换)
COMPOSE_VERSION=$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep 'tag_name' | cut -d\" -f4)
sudo curl -L "https://github.com/docker/compose/releases/download/${COMPOSE_VERSION}/docker-compose-$(uname -s)-$(uname -m)" \
    -o /usr/local/bin/docker-compose

# 权限配置
sudo chmod +x /usr/local/bin/docker-compose

# 验证安装
docker-compose --version

2.2 部署架构解析

Dify 的 Docker 部署包含以下核心组件:
Web 前端 API 服务 PostgreSQL Redis 模型服务

2.3 服务部署实战

步骤 1:获取部署清单
bash 复制代码
git clone -b main https://github.com/langgenius/dify.git && cd dify/docker

# 用户推荐使用镜像源:需要gitee账号
# git clone https://gitee.com/langgenius/dify.git
步骤 2:环境配置
bash 复制代码
cp .env.example .env

# 关键配置项建议修改
sed -i 's/HTTP_PORT=80/HTTP_PORT=5080/g' .env      # 避免端口冲突
sed -i 's/SUPERADMIN_EMAIL=.*/[email protected]/g' .env
步骤 3:配置镜像源
bash 复制代码
 #配置镜像加速源
 sudo nano /etc/docker/daemon.json

    "https://docker.1ms.run",
    "https://hub.rat.dev",
    "https://docker.1panel.live",
    "https://hub.rat.dev",
    "https://proxy.1panel.live",
    "https://ghcr.nju.edu.cn",
    "https://docker.registry.cyou",
    "https://dockercf.jsdelivr.fyi",
    "https://docker.rainbond.cc",
    "https://registry.cn-shenzhen.aliyuncs.com",
    "https://dockertest.jsdelivr.fyi",
    "https://mirror.aliyuncs.com",
    "https://mirror.baidubce.com",
    "https://docker.mirrors.ustc.edu.cn",
    "https://docker.mirrors.sjtug.sjtu.edu.cn",
    "https://mirror.iscas.ac.cn",
    "https://docker.nju.edu.cn",
    "https://docker.m.daocloud.io",
    "https://dockerproxy.com",
    "https://docker.jsdelivr.fyi",
    "https://docker-cf.registry.cyou"
    
    
    sudo systemctl daemon-reload
    sudo systemctl restart docker
步骤 4:启动服务集群
bash 复制代码
# 首次启动建议观察日志:下载速度可能比较慢
docker-compose up -d --build && docker-compose logs -f --tail=100

三、部署验证与初始化

3.1 服务状态检查

bash 复制代码
# 预期输出示例
docker-compose ps

root@wh-VMware-Virtual-Platform:~/dify/docker# docker-compose ps
NAME                     IMAGE                                       COMMAND                  SERVICE             CREATED             STATUS                    PORTS
docker-api-1             langgenius/dify-api:1.1.3                   "/bin/bash /entrypoi..."   api                 21 minutes ago      Up 21 minutes             5001/tcp
docker-db-1              postgres:15-alpine                          "docker-entrypoint.s..."   db                  21 minutes ago      Up 21 minutes (healthy)   5432/tcp
docker-nginx-1           nginx:latest                                "sh -c 'cp /docker-e..."   nginx               21 minutes ago      Up 21 minutes    

3.2 初始化管理员账户

  1. 访问 http://<your-server-ip>:80
  2. 按提示填写:
    • 组织名称
    • 管理员邮箱
    • 密码(复杂度要求:至少8位含大小写字母和数字)

四、高阶配置指南

4.1 反向代理配置(可选)

nginx 复制代码
#以上是全量安装已配置好nginx,可无需配置
server {
    listen 80;
    server_name dify.yourdomain.com;
    
    location / {
        proxy_pass http://localhost:5080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        
        # WebSocket 支持
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
    }
}

4.2 数据持久化配置(可选)

默认数据存储路径:

  • PostgreSQL:/var/lib/docker/volumes/dify_pg-data/_data
  • Redis:/var/lib/docker/volumes/dify_redis-data/_data

建议绑定到自定义目录:

yaml 复制代码
# 修改 docker-compose.yml
services:
  postgres:
    volumes:
      - /data/dify/postgres:/var/lib/postgresql/data
  redis:
    volumes:
      - /data/dify/redis:/data

五、故障排查手册

5.1 常见问题处理

问题 1:容器启动失败

✅ 排查步骤:

  1. 查看日志:docker-compose logs <service-name>
  2. 检查端口冲突:ss -tulnp | grep ':80'
  3. 验证依赖服务:确保 PostgreSQL/Redis 正常启动
问题 2:无法访问安装页面

✅ 解决方案:

  1. 检查防火墙设置:

    bash 复制代码
    sudo ufw allow 5080/tcp
  2. 验证服务绑定地址:

    bash 复制代码
    docker exec dify-web netstat -ant | grep 3000

六、维护与升级

6.1 服务更新流程

bash 复制代码
# 拉取最新代码
git pull origin main

# 重建服务
docker-compose down && docker-compose up -d --build

6.2 数据备份方案

bash 复制代码
# PostgreSQL 备份
docker exec dify-db pg_dump -U postgres dify > dify_backup_$(date +%Y%m%d).sql

# Redis 备份
docker exec dify-redis redis-cli save
cp /data/dify/redis/dump.rdp ./redis_backup_$(date +%Y%m%d).rdb

技术总结

本文详细阐述了 Dify 开源平台的容器化部署方案,具有以下技术亮点:

  1. 全栈隔离部署:通过 Docker Compose 实现服务组件隔离,确保环境一致性
  2. 生产级配置:包含反向代理、数据持久化等企业级部署方案
  3. 可观测性增强:提供完整的日志查看与状态监控命令
  4. 大陆优化方案:针对国内用户提供镜像加速配置建议

建议将本文所述方案部署于测试环境验证后,再迁移至生产环境。更多高级配置请参考 Dify 官方文档

如果本教程帮助您解决了问题,请点赞❤️收藏⭐支持!欢迎在评论区留言交流技术细节!

相关推荐
南郁5 小时前
005-nlohmann/json 基础方法-C++开源库108杰
c++·开源·json
struggle20256 小时前
Sim Studio 是一个开源的代理工作流程构建器。Sim Studio 的界面是一种轻量级、直观的方式,可快速构建和部署LLMs与您最喜欢的工具连接
人工智能·开源·deepseek
阿湯哥8 小时前
Kubernetes 与 Service Mesh 的深度集成指南
容器·kubernetes·service_mesh
遇见火星9 小时前
基于Docker的内网穿透实战:frp 0.68 + Nginx最佳实践
nginx·docker·容器·frp·内网穿透
孔令飞10 小时前
如何从GitHub上调研优秀的开源项目,并魔改应用于工作中?
ai·云原生·golang·kubernetes·开源·github
alden_ygq10 小时前
Kubernetes排错(七)-节点排错
云原生·容器·kubernetes
KrityCat12 小时前
查看并升级Docker里面Jenkins的Java17到21版本
java·docker·容器·jdk·jenkins
struggle202513 小时前
SurfSense开源程序是NotebookLM / Perplexity / Glean的开源替代品,连接到外部来源,如搜索引擎
人工智能·开源·自动化
alden_ygq16 小时前
K8S node ARP 表爆满 如何优化
容器·kubernetes·php
Silence4Allen17 小时前
Ubuntu 24.04 完整Docker安装指南:从零配置到实战命令大全
linux·ubuntu·docker