百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

安装Dify源码并修改前端发布

moboyou 2025-07-03 00:20 4 浏览

Dify 是一个开源的大语言模型(LLM)应用开发平台,目前是开源的,可以拿到完整的前后端源码,Dify 虽然开源协议,但要求前端代码保留版权协议和Logo;

今天讲下如何源码安装,并来修改打包前端代码

1 安装docker

由于我会用到整个开发环境,docker我用宝塔部署的,部署非常简单,直接安装完宝塔后,点击 docker 菜单安装即可:

由于docker镜像在国外,我们修改成国内镜像,点击 打开配置文件,将以下内容复制进去

{
"exec-opts": ["native.cgroupdriver=cgroupfs"],
"insecure-registries": [
"192.168.9.203:5000",
"192.168.9.203:8082",
"https://wtrtlz41.mirror.aliyuncs.com"
],
"log-driver": "json-file",
"log-opts": {
"max-file": "3",
"max-size": "100m"
},
"registry-mirrors": [
"https://docker.m.daocloud.io/",
"https://huecker.io/",
"https://dockerhub.timeweb.cloud",
"https://noohub.ru/",
"https://dockerproxy.com",
"https://docker.mirrors.ustc.edu.cn",
"https://docker.nju.edu.cn",
"https://xx4bwyg2.mirror.aliyuncs.com",
"http://f1361db2.m.daocloud.io",
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn"
],
"runtimes": {
"nvidia": {
"args": [],
"path": "nvidia-container-runtime"
}
}
}

复制完成后重启docker

2 安装python运行环境

# 安装 Miniconda
wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
bash Miniconda3-latest-Linux-x86_64.sh


#按照提示操作,当提示你是否“同意许可协议”时,输入 yes 并继续。然后,选择安装位置(通常直接按回车接受默认位置即可),并设置 Conda 的 PATH(建议选择 yes)。
echo 'export PATH="/root/miniconda3/bin:$PATH"' >> ~/.bashrc

#更新系统环境配置
source ~/.bashrc

# 验证安装
conda --version
conda init

# 运行环境
conda create -n dify python=3.12
conda activate dify

3 克隆源码

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

4 修改docker配置文件

由于我本机已经安装了pgsql 和 redis ,现在把 dify的 pgsql 和redis 默认的端口改下:

cd docker
vi docker-compose.middleware.yaml

# 第20行
ports:
      - "${EXPOSE_POSTGRES_PORT:-5433}:5432"

# 第39行
ports:
      - "${EXPOSE_REDIS_PORT:-6380}:6379"

# 执行:
docker compose -f docker-compose.middleware.yaml up -d

5 安装后台服务环境

cd api


#2. 备份配置文件
cp .env.example .env


#3. 生成随机密钥:
#此条命令会在.env配置文件里的SECRET_KEY配置项后面追加一串随机符
awk -v key="$(openssl rand -base64 42)" '/^SECRET_KEY=/ {sub(/=.*/, "=" key)} 1' .env > temp_env && mv temp_env .env
# 4. 修改.env配置文件相关配置:
#例如PostgreSQL\Redis\Weaviate\Celery的相关连接配置,请根据实际的情况对应修改
#安装配置poerty,一般安装pip时会有poetry,可用pip list查看,若没有再行安装,本示例使用1.8.5
pip install poetry==1.8.5
poetry env use 3.12
poetry lock --no-update


#安装依赖,注意该命令的执行目录要在包含poetry的相关文件的目录下执行方可生效
poetry source add --default mirrors https://pypi.tuna.tsinghua.edu.cn/simple
poetry source add --default mirrors https://mirrors.aliyun.com/pypi/simple/
poetry install
poetry install --no-interaction --no-ansi --timeout 1000


# 安装onnxruntime
# https://pypi.org/project/onnxruntime/#files
poetry add ./onnxruntime-1.20.1-cp312-cp312-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl 
poetry shell
poetry run python -m flask db upgrade


# 启动api服务
poetry run python -m flask run --host 0.0.0.0 --port=5001 --debug


#Linux/MacOS:
pip install celery == 5.3.0
poetry install
 
# 启动后台进程
celery -A app.celery worker -P gevent -c 1 -Q dataset,generation,mail,ops_trace --loglevel INFO


#Windows:
pip install celery == 5.3.0
poetry install
celery -A app.celery worker -P solo --without-gossip --without-mingle -Q dataset,generation,mail,ops_trace --loglevel INFO

6 安装前端运行环境

cd web
cp .env.example .env

apt install npm
npm config set registry https://registry.npmmirror.com
npm install -g n

n latest
sudo npm install -g pnpm

# 服务打包
pnpm install
pnpm run build
pnpm run start

启动后,默认是 3000端口,如下:

以上代码就跑起来了,下面我们改下代码:dify默认会打开个 Start Chat 确认页面,如下图:

我们来写个代码去掉它:

在这里:\web\app\components\base\chat\chat-with-history\config-panel\index.tsx 加入代码

 useEffect(() => {
    // 在组件挂载后立即调用 handleStartChat
    handleStartChat();
  }, [handleStartChat]); // 依赖项数组中包含 handleStartChat,确保它变化时重新执行

重新打包 发布:

pnpm run build
pnpm run start

再打开,可以直接进入对话了!

相关推荐

惊艳所有安卓程序员!京东T8纯手码的安卓开发相关源码精编解析

Android系统的源代码非常庞大和复杂,我们不能贸然进入,否则很容易在里面迷入方向,进而失去研究它的信心。我们应该在分析它的源代码之前学习好一些理论知识,下面就介绍一些与Android系统相关的资料...

「黑客编程」手把手教你编写POC

1概述1.1什么是POC?POC(全称:Proofofconcept),中文译作概念验证。在安全界可以理解成漏洞验证程序。和一些应用程序相比,PoC是一段不完整的程序,仅仅是为了证明提出...

社交媒体登录Spring Social的源码解析

在上一篇文章中我们给大家介绍了OAuth2授权标准,并且着重介绍了OAuth2的授权码认证模式。目前绝大多数的社交媒体平台,都是通过OAuth2授权码认证模式对外开放接口(登录认证及用户信息接口等)。...

网站后端开发源代码

成人网站在推动Web发展方面发挥的作用是不可否认的。从克服浏览器视频功能的限制到使用WebSockets推送广告(以防止广告拦截器拦截广告),您必须不断想出巧妙的方法,才能让自己处于Web...

Java语言的智能名片系统源码,二次开发流程

在数字化转型浪潮中,智能名片系统已成为企业营销的基础设施。本文将手把手教你如何部署一套基于Java的智能名片系统源码,涵盖技术选型、环境搭建、部署实施和二次开发全流程。一、系统架构设计1.1技术栈选...

小程序源码交付标准详解:必备内容与注意事项

在定制化小程序开发项目中,源码交付是确保客户后续自主运维、二次开发的关键环节。然而,许多客户在验收时才发现交付内容不全,导致项目无法正常部署或升级。本文将系统梳理小程序源码交付的**必备内容**、**...

安装Dify源码并修改前端发布

Dify是一个开源的大语言模型(LLM)应用开发平台,目前是开源的,可以拿到完整的前后端源码,Dify虽然开源协议,但要求前端代码保留版权协议和Logo;今天讲下如何源码安装,并来修改打包前端代码...

Android系统基础(03) Android系统源码下载

常规官方网站说明:Android源码官方网站为(google你懂的):https://source.android.com官网参考链接,对应的tag(tag是一种标签,我们可以根据tag来判断下载的...

不靠Agent,4步修复真Bug!蚂蚁CGM登顶SWE-Bench开源榜

机器之心报道编辑:吴昕Agentless+开源模型,也能高质量完成仓库级代码修复任务,效果媲美业界SOTA。一、Agentless、44%与NO.1说到AI写代码的实力,大家最关心的还是...

VS Code使用Git可视化管理源代码详细教程

前言:  随着VSCode的功能和插件的不断强大和完善,它已经成为了我们日常开发中一个必不可缺的伙伴了。在之前我曾经写过一篇SourceTree使用教程详解(一个git可视化管理神器,想要了解的话可...

SpringMVC + Spring + Mybatis + Shiro + 教务查询系统源码分享

功能模块介绍源码获取先转发,然后加关注,私信“源码”即可免费获取登录模块功能使用Shiro权限管理框架,实现登录验证和登录信息的储存,根据不同的登录账户,分发权限角色,对不同页面url进行角色设置...

PHP漏洞之跨网站请求伪造

CSRF(CrossSiteRequestForgeries),意为跨网站请求伪造,也有写为XSRF。攻击者伪造目标用户的HTTP请求,然后此请求发送到有CSRF漏洞的网站,网站执行此请求后,...

Dify工具使用全场景:dify-web修改编译指南(源码解读篇·第1期)

我的场景最近一直在研究dify怎么用,怎么用好,要想研究深了,还是得看源码,首先就是要把界面改改,当前的界面太素了,不了解web源码,没法改。所以静下来看了看源码,发现也不难,正好给大家也分享一下修改...

SKIT.FlurlHttpClient.Wechat实现微信接口开发-服务器验证回调

1.在微信公众后台配置设置以下内容开发者密码(AppSecret)IP白名单,就是使用哪一个服务器来控制当前公众号l令牌服务器地址(URL):使用哪一个Url来验证服务器是可以进行开发令牌(To...

PHP和NodeJS的代码执行效率比较

在瞬息万变的网络开发领域中,选择合适的技术栈对于构建高效且可扩展的应用程序至关重要。在众多后端技术中,PHP与Node.js常常成为开发者热议的焦点。Node.js以其非阻塞、事件驱动的架构著称,而P...