开源 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 官方文档

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

相关推荐
AI服务老曹3 分钟前
通过平台大数据智能引擎及工具,构建设备管理、运行工况监测、故障诊断等应用模型的智慧快消开源了
大数据·科技·物联网·开源·云计算
z日火1 小时前
Windows Server 2019 安装 Docker 完整指南
windows·docker·容器
邹卓为1 小时前
docker 安装 jenkins
java·docker·jenkins
弧襪2 小时前
Docker Swarm 集群
docker·容器·eureka
掉头发的王富贵2 小时前
Typora结合PicList&PicGo实现Gitee免费图床
git·开源·github
FIT2CLOUD飞致云3 小时前
速来体验丨1Panel支持一键部署MCP Server,告别繁琐配置!
人工智能·开源
就新年快乐吧3 小时前
【HD-RK3576-PI】Docker搭建与使用
linux·docker
alden_ygq9 小时前
k8s node inode被耗尽如何处理?
云原生·容器·kubernetes
爱知菜10 小时前
Windows安装Docker Desktop(WSL2模式)和Docker Pull网络问题解决
运维·docker·容器
FIT2CLOUD飞致云11 小时前
四月月报丨MaxKB正在被能源、交通、金属矿产等行业企业广泛采纳
人工智能·开源