百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Dify-Plus:一个定制化的Dify二开开发

liuian 2025-04-24 03:32 24 浏览

Dify 是一个开源平台,专注于大语言模型(LLM)应用的开发。它结合了后端即服务(BaaS)和 LLMOps 的概念,致力于为开发者提供高效工具,使其能够快速构建并部署生产级的生成式 AI 应用。

在探索技术产品的征途中,我们认识到每一款创新之作,包括Dify,都携带着其独特的局限。深入剖析这些限制,不仅能够让我们在运用的天平上更精准地衡量得失,更能让我们在扬长避短中,将Dify的潜力发挥至极致,同时巧妙地绕过那些可能潜伏的陷阱。

Dify-Plus = 管理中心 + Dify 二开开发

Dify-Plus作为Dify的升级企业版本,深度融合了gin-vue-admin框架的管理核心,并精心打造,以满足企业级应用的需求,通过一系列的功能强化和优化,为商业环境提供了更加专业和高效的解决方案。

Dify 二开功能


Dify 的二次开发引入了多项新功能与优化,旨在提升用户体验和系统效能。新增功能包括用户额度管理,通过对话余额限制判断和异步计算用户额度逻辑,确保资源的合理分配。用户界面左上角新增了使用额度显示,以及个人监测页,增强了透明度和自我管理能力。

在安全性方面,新增了密钥额度设置和应用API调用余额限制判断,强化了系统的安全防线。Web公开页登录鉴权功能的加入,为公开访问提供了额外的安全层。管理员现在可以同步应用到应用模板,而初次注册用户将默认加入默认空间,简化了用户流程。


新增的可鉴权cookie功能,以及同步应用到模板中心的能力,进一步提升了系统的灵活性和可扩展性。应用中心页面的新增,以及默认跳转到应用中心的调整,优化了用户导航体验。应用使用次数记录和排序功能的加入,使得应用中心更加动态和用户友好。


权限方面进行了调整,普通成员不再被允许关闭模型,空间普通成员不渲染“模型供应商”标签,非管理员隐藏密钥显示,这些调整强化了权限管理和安全策略。

在技术优化方面,CSV编码监测的优化,修复了批量请求和Windows系统下载后保存再上传的问题。Markdown图片放大问题的优化,提升了文档编辑的体验。


管理中心

管理中心的功能也得到了扩展,包括JWT与Dify的打通,用户同步,模型同步工作区,用户额度修改,以及费用报表的生成,这些功能共同构建了一个更加集成和高效的管理平台。


Docker-Compose 部署指南

克隆项目

  1. 1. 克隆代码库:git clone git@github.com:YFGaia/dify-plus.git

使用 Docker 启动

  1. 1. 进入项目的 Docker 目录:cd dify-plus/docker
  2. 2. 启动 Docker 容器:docker-compose -f docker-compose.dify-plus.yaml up -d
  3. 3. 检查服务状态:docker compose ps

初始化管理员账户

  • o 访问 http://127.0.0.1/install 创建 Dify 管理员账号。

部署服务步骤

前置依赖

  • o Python: 3.11 或 3.12
  • o Node.js: >= 18.17.0
  • o Golang: >= 1.22.0
  • o Redis
  • o PostgreSQL

API 服务启动步骤


  1. 详见:https://docs.dify.ai/zh-hans/getting-started/install-self-hosted/local-source-code#fu-wu-duan-bu-shu

  2. 1. 进入 API 目录:cd api
  3. 2. 复制环境变量配置:cp .env.example .env
  4. 3. 生成并设置随机密钥:awk -v key="$(openssl rand -base64 42)" '/^SECRET_KEY=/ {sub(/=.*/, "=" key)} 1' .env > temp_env && mv temp_env .env
  5. 4. 安装依赖:poetry env use 3.11
    poetry install
  6. 5. 数据库迁移:poetry shell
    flask db upgrade
  7. 6. 启动 API 服务:flask run --host 0.0.0.0 --port=5001 --debug

启动 Dify Web 服务


  1. 详见:https://docs.dify.ai/zh-hans/getting-started/install-self-hosted/local-source-code#qian-duan-ye-mian-bu-shu

  2. 1. 进入 web 目录:cd web
  3. 2. 安装依赖:npm install
  4. 3. 复制环境变量配置:cp .env.example .env.local
  5. 4. 根据需要编辑环境变量:vim .env.local
  6. 5. 构建前端代码:npm run build
  7. 6. 启动 Web 服务:npm run start

启动 Dify Worker 服务

  • o Linux/MacOS:celery -A app.celery worker -P gevent -c 1 -Q dataset,generation,mail,ops_trace,extend_high,extend_low --loglevel INFO
  • o Windows:celery -A app.celery worker -P solo --without-gossip --without-mingle -Q dataset,generation,mail,ops_trace,extend_high,extend_low --loglevel INFO

启动 Dify Beat 服务

celery -A app.celery beat --loglevel INFO

启动 Admin-Web 服务

  1. 1. 进入 Admin-Web 目录:cd admin/web
  2. 2. 安装依赖:yarn install
  3. 3. 启动服务:yarn run serve

启动 Admin-Server 服务

  1. 1. 进入 Admin-Server 目录:cd admin/server
  2. 2. 整理模块依赖:go mod tidy
  3. 3. 启动服务:go run main.go

初始化管理员账户

  • o 访问 http://localhost:3000/install 以设置管理员账号。
  • o 在管理中心页面 http://localhost:8081/#/init 填写数据库配置并进行初始化。


·


我们相信人工智能为普通人提供了一种“增强工具”,并致力于分享全方位的AI知识。在这里,您可以找到最新的AI科普文章、工具评测、提升效率的秘籍以及行业洞察。


欢迎关注“福大大架构师每日一题”,让AI助力您的未来发展。

·

相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...