ubuntu16.04部署dify教程

文章目录

  • 1、克隆 Dify 源代码至本地环境
  • 2、加速Dify镜像文件下载
  • 3、启动 Dify
  • 4、访问 Dify
  • 5、更新 Dify
  • 6、常见问题及解决方案
    • (1)容器restarting
    • (2)日志文件上限
    • (3)重置管理员密码
    • (4)修改页面端口

Dify 是一个基于 Docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它通过容器化每个步骤,确保工作流的可复现性和环境一致性。Dify 支持自动化执行、日志记录和结果管理,适用于数据处理、模型训练和部署等场景。

Dify 主要支持以下三种模式:
Agent 模式:Dify 作为一个代理,通过配置和管理多种工作流,进行任务调度和执行。
知识库模式:用于存储和管理工作流相关的知识、数据库和模型,方便复用和共享。
工作流模式:Dify 通过定义工作流的各个步骤,自动化执行数据处理、模型训练、测试等任务,确保工作流的一致性和高效性。

安装 Dify 之前, 请确保机器已满足最低安装要求:
CPU >= 2 Core
RAM >= 4 GiB

1、克隆 Dify 源代码至本地环境

git clone https://github.com/langgenius/dify.git

也可以手动下载到本地https://github.com/langgenius/dify/archive/refs/heads/main.zip,解压后移动到服务器上。

2、加速Dify镜像文件下载

详情见:https://github.com/imashen/docker-aio/tree/main

  • 安装脚本使用:curl -fsSL https://docker.13140521.xyz/install | bash -s docker --mirror Aliyun

  • Docker加速源使用:

  • 编辑Docker配置文件: 打开Docker的配置文件(通常位于/etc/docker/daemon.json):sudo vim /etc/docker/daemon.json

  • 添加或修改镜像源: 添加或修改配置文件中的registry-mirrors字段:

{"registry-mirrors": ["https://docker.13140521.xyz"]
}
  • 重启Docker服务: 保存配置文件并重启Docker服务:
sudo systemctl daemon-reload
sudo systemctl restart docker

3、启动 Dify

进入 Dify 源代码的 Docker 目录cd dify/docker
复制环境配置文件cp .env.example .env
启动 Docker 容器
根据你系统上的 Docker Compose 版本,选择合适的命令来启动容器。你可以通过docker compose version命令检查版本,详细说明请参考 Docker 官方文档:
如果版本是 Docker Compose V2,使用以下命令:

docker compose up -d

如果版本是 Docker Compose V1,使用以下命令:

docker-compose up -d

运行命令后,你应该会看到类似以下的输出,显示所有容器的状态和端口映射:

[+] Running 11/11✔ Network docker_ssrf_proxy_network  Created                                                                 0.1s ✔ Network docker_default             Created                                                                 0.0s ✔ Container docker_redis_1           Started                                                                 2.4s ✔ Container docker_ssrf_proxy_1      Started                                                                 2.8s ✔ Container docker_sandbox_1         Started                                                                 2.7s ✔ Container docker_web_1             Started                                                                 2.7s ✔ Container docker_weaviate_1        Started                                                                 2.4s ✔ Container docker_db_1              Started                                                                 2.7s ✔ Container docker_api_1             Started                                                                 6.5s ✔ Container docker_worker_1          Started                                                                 6.4s ✔ Container docker_nginx_1           Started                                                                 7.1s

最后检查是否所有容器都正常运行:

docker compose ps
NAME                  IMAGE                              COMMAND                   SERVICE      CREATED              STATUS                        PORTS
docker_api_1          langgenius/dify-api:0.6.13         "/bin/bash /entrypoi…"   api          About a minute ago   Up About a minute             5001/tcp
docker_db_1           postgres:15-alpine                 "docker-entrypoint.s…"   db           About a minute ago   Up About a minute (healthy)   5432/tcp
docker_nginx_1        nginx:latest                       "sh -c 'cp /docker-e…"   nginx        About a minute ago   Up About a minute             0.0.0.0:80->80/tcp, :::80->80/tcp, 0.0.0.0:443->443/tcp, :::443->443/tcp
docker_redis_1        redis:6-alpine                     "docker-entrypoint.s…"   redis        About a minute ago   Up About a minute (healthy)   6379/tcp
docker_sandbox_1      langgenius/dify-sandbox:0.2.1      "/main"                   sandbox      About a minute ago   Up About a minute             
docker_ssrf_proxy_1   ubuntu/squid:latest                "sh -c 'cp /docker-e…"   ssrf_proxy   About a minute ago   Up About a minute             3128/tcp
docker_weaviate_1     semitechnologies/weaviate:1.19.0   "/bin/weaviate --hos…"   weaviate     About a minute ago   Up About a minute             
docker_web_1          langgenius/dify-web:0.6.13         "/bin/sh ./entrypoin…"   web          About a minute ago   Up About a minute             3000/tcp
docker_worker_1       langgenius/dify-api:0.6.13         "/bin/bash /entrypoi…"   worker 

4、访问 Dify

你可以先前往管理员初始化页面设置管理员账户:

本地环境

http://localhost/install

服务器环境

http://your_server_ip/install

Dify 主页面:

本地环境

http://localhost

服务器环境

http://your_server_ip

5、更新 Dify

进入 dify 源代码的 docker 目录,按顺序执行以下命令:

# 注意:以下方法只针对git clone方式下载的小伙伴
cd dify/docker
docker compose down
git pull origin main
docker compose pull
docker compose up -d

同步环境变量配置 (重要!)
如果 .env.example 文件有更新,请务必同步修改你本地的 .env 文件。

检查 .env 文件中的所有配置项,确保它们与你的实际运行环境相匹配。你可能需要将 .env.example 中的新变量添加到 .env 文件中,并更新已更改的任何值。
如果是通过下载dify压缩文件到本地的小伙伴,请重新下载最新的dify压缩文件并移动到服务器覆盖当前dify目录。接着进入 api 目录下,执行以下命令将数据库结构迁移至最新版本flask db upgrade。接着,运行docker-compose up -d即可。

6、常见问题及解决方案

(1)容器restarting

通过docker compose ps,如果出现个别容器一直restarting,使用docker logs -f查看容器日志,如果日志中出现如下错误:

- OpenBLAS blas_thread_init: pthread_create failed for thread 47 of 48: Operation not permittedOpenBLAS blas_thread_init: RLIMIT_NPROC -1 current, -1 max

修改docker-compose.yaml文件,在每个镜像下增加privileged: true # 启用特权模式,如:

api:image: langgenius/dify-api:0.13.1restart: alwaysenvironment:# Use the shared environment variables.<<: *shared-api-worker-env# Startup mode, 'api' starts the API server.MODE: apidepends_on:- db- redisvolumes:# Mount the storage directory to the container, for storing user files.- ./volumes/app/storage:/app/api/storagenetworks:- ssrf_proxy_network- defaultprivileged: true

通过docker-compose down停止所有正在运行的容器,然后docker-compose up -d重新启动所有dify镜像即可解决。

(2)日志文件上限

当前docker日志文件没有设置上限,会导致日志文件占用内存持续增长,可通过以下方式设置单个日志文件的上限:

api:image: langgenius/dify-api:0.13.1restart: alwaysenvironment:# Use the shared environment variables.<<: *shared-api-worker-env# Startup mode, 'api' starts the API server.MODE: apidepends_on:- db- redisvolumes:# Mount the storage directory to the container, for storing user files.- ./volumes/app/storage:/app/api/storagenetworks:- ssrf_proxy_network- defaultprivileged: truelogging:driver: "json-file"options:max-size: "10m"     # 每个日志文件最大 10MBmax-file: "3" 

(3)重置管理员密码

如果你通过 Docker Compose 部署,你可以运行以下 Docker Compose 命令行重置密码。

docker exec -it docker_api_1 flask reset-password

请按照提示输入邮箱地址和新密码,例如:

dify@my-pc:~/hello/dify/docker$ docker compose up -d
[+] Running 9/9✔ Container docker_web_1         Started                                                              0.1s ✔ Container docker_sandbox_1     Started                                                              0.1s ✔ Container docker_db_1          Started                                                              0.1s ✔ Container docker_redis_1       Started                                                              0.1s ✔ Container docker_weaviate_1    Started                                                              0.1s ✔ Container docker_ssrf_proxy_1  Started                                                              0.1s ✔ Container docker_api_1         Started                                                              0.1s ✔ Container docker_worker_1      Started                                                              0.1s ✔ Container docker_nginx_1       Started                                                              0.1s 
dify@my-pc:~/hello/dify/docker$ docker exec -it docker-api-1 flask reset-password
None of PyTorch, TensorFlow >= 2.0, or Flax have been found. Models won't be available and only tokenizers, configuration and file/data utilities can be used.
sagemaker.config INFO - Not applying SDK defaults from location: /etc/xdg/sagemaker/config.yaml
sagemaker.config INFO - Not applying SDK defaults from location: /root/.config/sagemaker/config.yaml
Email: hello@dify.ai
New password: newpassword4567
Password confirm: newpassword4567
Password reset successfully.

(4)修改页面端口

如果你使用 Docker Compose 部署,你可以通过修改.env配置来自定义 Dify 的访问端口。

你需要修改 Nginx 相关配置:

EXPOSE_NGINX_PORT=80
EXPOSE_NGINX_SSL_PORT=443

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/487025.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件项目标书参考,合同拟制,开发合同制定,开发协议,标书整体技术方案,实施方案,通用套用方案,业务流程,技术架构,数据库架构全资料下载(原件)

1、终止合同协议书 2、项目合作协议 3、合同交底纪要 4、合同管理台账 软件资料清单列表部分文档清单&#xff1a;工作安排任务书&#xff0c;可行性分析报告&#xff0c;立项申请审批表&#xff0c;产品需求规格说明书&#xff0c;需求调研计划&#xff0c;用户需求调查单&…

PADS系列:绘制RTL8306原理图的过程

大家好&#xff0c;我是山羊君Goat。 在所有相关的元件都被创建到了原理图库之后&#xff0c;就可以正式开始原理图的绘制了。不过绘制过程中也是会按照一定的顺序来进行的&#xff0c;这样可以达到事半功倍的效果。 首先就是主芯片的放置&#xff0c;这里有三个主芯片&#x…

c++:多态性

c三大特性&#xff1a;封装、继承、多态&#xff0c;其实这三者是相互联系的&#xff0c;相互包含的 1.概念 1.1编译时多态性&#xff08;静态多态性&#xff09; 主要通过函数重载和运算符重载来实现在编译时&#xff0c;编译器根据函数调用的参数类型或运算符的操作数类型来…

(ICML-2024)DoRA:权重分解低秩自适应

DoRA&#xff1a;权重分解低秩自适应 Paper是英伟达发表在ICML 2024的工作 Paper Title&#xff1a;DoRA: Weight-Decomposed Low-Rank Adaptation Code&#xff1a; 地址 Abstract 在广泛使用的参数高效微调 (PEFT) 方法中&#xff0c;LoRA 及其变体因避免了额外的推理成本而…

微信小程序从后端获取的图片,展示的时候上下没有完全拼接,有缝隙【已解决】

文章目录 1、index.wxml2、index.js3、detail.detail为什么 .rich-text-style 样式可以生效&#xff1f;1. <rich-text> 组件的特殊性2. 类选择器的作用范围3. 样式优先级4. line-height: 0 的作用5. 为什么直接使用 rich-text 选择器无效&#xff1f; 总结 上下两张图片…

基于单片机的空调温度控制器设计

摘 要 随着国民经济的发展和人民生活水平的提高&#xff0c;空调已被广泛应用于社会的各种场合。空调因具有节能、低噪、恒温控制、全天候运转、启动低频补偿、快速达到设定温度等性能&#xff0c;大大提高了其舒适性&#xff0c;得到越来越多的人们的喜爱。单片机和数字温度传…

ElasticSearch常见的索引_集群的备份与恢复方案

方案一&#xff1a;使用Elasticsearch的快照和恢复功能进行备份和恢复。该方案适用于集群整体备份与迁移&#xff0c;包括全量、增量备份和恢复。 方案二&#xff1a;通过reindex操作在集群内或跨集群同步数据。该方案适用于相同集群但不同索引层面的迁移&#xff0c;或者跨集…

【计算机网络】实验12:网际控制报文协议ICMP的应用

实验12 网际控制报文协议ICMP的应用 一、实验目的 验证ping命令和tracert命令的工作原理。 二、实验环境 Cisco Packet Tracer模拟器 三、实验过程 1.构建网络拓扑并进行信息标注&#xff0c;将所需要配置的IP地址写在对应的主机或者路由器旁边&#xff0c;如图1所示。 图…

Redis安装和Python练习(Windows11 + Python3.X + Pycharm社区版)

环境 Windows11 Python3.X Pycharm社区版 思路 1 github下载redis压缩包 &#xff0c;安装并启动redis服务&#xff0c;在客户端连接redis服务。 2 在pycharm中运行python程序&#xff0c;连接redis服务&#xff0c;熟悉redis的使用和巩固python语言。 3 python开发环境…

8.解决跨域问题的三种方案

开启域名&#xff0c;单点登录后&#xff0c;就使用最上面的接口了

【机器学习】基础知识:拟合度(Goodness of Fit)

拟合度概念及意义 拟合度&#xff08;Goodness of Fit&#xff09;是衡量统计模型对数据解释能力的指标&#xff0c;用于评价模型对观测数据的拟合效果。在回归分析、分类模型或其他预测模型中&#xff0c;拟合度是模型性能的重要衡量标准。 1. 拟合度的作用 拟合度的主要作用…

【Elasticsearch】实现用户行为分析

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/literature?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;…

初识Linux · 线程同步

目录 前言&#xff1a; 认识条件变量 认识接口 快速使用接口 生产消费模型 前言&#xff1a; 前文我们介绍了线程互斥&#xff0c;线程互斥是为了防止多个线程对临界资源访问的时候出现了对一个变量同时操作的情况&#xff0c;对于线程互斥来说&#xff0c;我们使用到了锁…

使用 LlamaFactory 结合开源大语言模型实现文本分类:从数据集构建到 LoRA 微调与推理评估

文章目录 背景介绍文本分类数据集Lora 微调模型部署与推理期待模型的输出结果 文本分类评估代码 背景介绍 本文将一步一步地&#xff0c;介绍如何使用llamafactory框架利用开源大语言模型完成文本分类的实验&#xff0c;以 LoRA微调 qwen/Qwen2.5-7B-Instruct 为例。 文本分类…

【已解决】MacOS上VMware Fusion虚拟机打不开的解决方法

在使用VMware Fusion时&#xff0c;不少用户可能会遇到虚拟机无法打开的问题。本文将为大家提供一个简单有效的解决方法&#xff0c;只需删除一个文件&#xff0c;即可轻松解决这一问题。 一、问题现象 在MacOS系统上&#xff0c;使用VMware Fusion运行虚拟机时&#xff0c;有…

【教程】创建NVIDIA Docker共享使用主机的GPU

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 这套是我跑完整理的。直接上干货&#xff0c;复制粘贴即可&#xff01; # 先安装toolkit sudo apt-get update sudo apt-get install -y ca-certifica…

设备CTA进网许可认证有哪些值得注意的测试内容?

设备进网许可认证的测试项目与测试内容有哪些?在CTA进网认证过程中是否存在需要注意的地方?本篇是英利检测针对这两点给大家进行的资料整理&#xff0c;帮助大家更进一步了解项目难点所在。 一、电磁兼容测试(EMC测试) 电磁兼容测试旨在评估设备在电磁环境中的表现&#xff0…

flex布局容易忽略的角色作用

目录 清除浮动 作用于行内元素 flex-basis宽度 案例一&#xff1a; 案例二&#xff1a; 案例三&#xff1a; flex-grow设置权重 案例一&#xff1a; 案例二&#xff1a; 简写flex-grow:1 0 auto; 目录 清除浮动 作用于行内元素 flex-basis宽度 案例一&#xff1a…

vue自定义弹窗点击除了自己区域外关闭弹窗

这里使用到vue的自定义指令 <div class"item" v-clickoutside"clickoutside1"><div click"opencity" class"text":style"{ color: popup.iscitypop || okcitylist.length ! 0 ? #FF9500 : #000000 }">选择地区…

旧衣物回收小程序搭建,便捷回收,绿色生活!

随着人们生活水平的提高&#xff0c;各种衣物的更新速度逐渐加快&#xff0c;为了减少衣物的浪费&#xff0c;旧衣物回收市场受到了人们的关注。 如今&#xff0c;旧衣物回收行业的技术正在不断创新&#xff0c;利用科技的发展&#xff0c;结合了互联网的模式&#xff0c;提高…