基于Dify平台构建AI应用

2022年底openAI的chatgpt的出现,让人们看到生成式AI的能力如此强大,引燃了生成式AI的一波浪潮。2025年春节前,DeepSeek的横空出世让大模型这个领域变得人人都可以参与进来,生成式AI大模型不再有非常高的显卡的门槛,普通的游戏本也能跑DeepSeek的蒸馏版8b模型。目前大模型有两个落地应用的方向,一个是知识库(知识增强,RAG),一个是智能体(Agent)。对于知识库来说,企业内部的大量私有化数据不适合放到外网应用,那么就诞生了私有化部署大模型的需求。而另一个方向智能体,它让我们的应用能够自动化、智能化的实现,让大模型变成我们的私人助理,提升我们的工作效率和生活体验。

那么我们怎么来实现知识库和智能体呢?目前有很多平台可以应用,比如Coze、Dify、langchain…,这些都是很有名气的平台或者框架,在github上面也很受欢迎。但是现阶段综合来看,Dify是一个更有优势的AI应用平台。Dify的官方主页 https://dify.ai/zh。

Dify主要优势如下:

  1. 能够私有化部署
    这很重要!企业的私有化数据隐私性很强,不适合放到外网区。Dify的开源版本可以零成本的克隆到企业内网使用,无需连外网。安全性得以保证。
  2. 可视化拖拽方式开发工作流
    通过可视化的界面,Dify可以快速构建各类工作流应用。
  3. Dify提供完整的AI基础设施
    Dify为AI应用提供从构思、开发到部署、监控的全流程管理,可以10倍的提升AI应用开发体验。

本篇博客主要讲解Windows环境下的Dify平台的搭建。

安装Docker

Docker是一个非常好用的容器化管理工具。使用它可以不用担心应用环境依赖的问题,直接拉取别人打包好的镜像使用即可,做到一键式部署。安装Docker可以去其官方网站下载,https://www.docker.com/。

在这里插入图片描述

安装好Docker之后,我们可以在设置里面修改一下Docker的更新源,以便后面安装Dify时速度更快。

在这里插入图片描述

安装Dify

可以去Dify的github上面下载Dify的开源版本 https://github.com/langgenius/dify,clone项目到本地,docker启动。

克隆项目到本地后,进入到 dify-main\docker 目录下,启动cmd窗口。执行 docker compose up -d 命令。然后就耐心等待下载安装。

因为安装Dify涉及到的镜像比较多,跟网络关系很大。如果中途中断失败了,可以多次尝试安装。安装成功之后,会有Success的提示。

具体的安装过程可以参考Dify的说明文档 https://docs.dify.ai/zh-hans/getting-started/install-self-hosted/docker-compose。

启动Docker容器中的Dify

在这里插入图片描述
默认Dify应用的端口是80,如果说有其他应用占用了这个端口号,那么就需要先修改。在Dify的Docker目录下,docker-compose.yaml配置文件中找到ports节点,将其端口号由80修改为8080或者其它端口。

在这里插入图片描述
启动Docker之后,我们就可以在浏览器中打开Dify了。如我的地址 http://127.0.0.1:8080/apps 。

在这里插入图片描述

Dify中配置本地大模型

  1. 配置文件启用OLLAMA自定义模型
    在配置本地大模型之前,先要配置一下Dify的Docker目录下的.env.example文件。
    在这个文件的最后添加如下配置:
    在这里插入图片描述
    其中OLLAMA_MODELS是我本地的大模型下载安装地址。OLLAMA_API_BASE_URL设置的地址,下面Dify中配置Ollama需要用到。
  2. Dify应用中关联模型
    在 部署离线版DeepSeek 这篇博客中,曾经通过Ollama将大模型下载到本地。这里可以在其基础上,在Dify中配置Ollama本地模型。这样我们的应用就可以完全在本地跑,不需要在线调用其他大模型的API,实现本地应用。

在这里插入图片描述
在这里插入图片描述
如图中所示,我的Ollama本地下载了DeepSeek的8b和14b模型以及嵌入模型bge-m3,然后在模型设置中选择对应的模型即可。

PS:如上便完成了Dify在Windows环境下的部署安装。2025年AI大模型落地了,赶紧玩起来吧 _

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

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

相关文章

Python tikinter实现打开指定ip的电脑摄像头

以下是一个使用Python的tkinter和OpenCV库实现打开指定IP摄像头的应用程序。这个程序允许用户输入IP摄像头的URL,并实时显示摄像头画面,同时支持截图和录制功能。 登录后复制 import tkinter as tk from tkinter import ttk, messagebox, filedialog imp…

OpenCV插值方法详解:原理、应用与代码实践

一、引言 在数字图像处理中,插值是一种基本且重要的技术,它广泛应用于图像缩放、旋转、几何变换等场景。OpenCV作为最流行的计算机视觉库之一,提供了多种插值方法供开发者选择。本文将全面介绍OpenCV中的插值技术,包括各种方法的…

创客匠人解析:身心灵赛道创始人 IP 打造核心策略

在当代社会焦虑情绪蔓延的背景下,身心灵赛道正以万亿级市场规模成为知识变现的新蓝海。作为知识变现领域的重要参与者,创客匠人通过服务超 5W 知识博主的实践经验,揭示了该赛道中创始人 IP 打造的底层逻辑 ——IP 不仅是形象符号&#xff0c…

Rust 和C++工业机器人实践

Rust 调用Cursor案例 Cursor 的这些功能可以显著提升开发效率,减少重复劳动,适合个人开发者和团队协作使用。 读取文件内容并处理 使用Cursor读取文件内容并逐行处理: use std::io::{Cursor, BufRead};let data = "Line 1\nLine 2\nLine 3".as_bytes(); let c…

llama.cpp学习笔记:后端加载

单例 struct ggml_backend_registry {std::vector<ggml_backend_reg_entry> backends;std::vector<ggml_backend_dev_t> devices;// ... }struct ggml_backend_reg_entry {ggml_backend_reg_t reg;dl_handle_ptr handle; };typedef struct ggml_backend_reg * ggm…

Prompt工程标准化在多模型协同中的作用

&#x1f680; 在AI模型"群雄逐鹿"的时代&#xff0c;如何让这些"AI武林高手"协同作战&#xff1f;答案可能藏在一个看似平凡却至关重要的概念中&#xff1a;Prompt工程标准化。 &#x1f4da; 文章目录 引言&#xff1a;AI模型的"巴别塔"困境什…

Java面试宝典:基础五

104. 源文件命名规则 题目:主类名为 a1,保存它的源文件可以是? 选项: A. a1.java B. a1.class C. a1 D. 都对 答案:A 解析: Java 源文件必须与公共类名完全匹配(区分大小写),后缀为 .java。.class 是编译后的字节码文件,非源文件。105. Java类的本质 题目:Java类…

Pycaita二次开发基础代码解析:几何特征统计、跨零件复制与发布技术的工业级实现

本文将从工业实践角度深入剖析CATIA二次开发中的三项核心技术&#xff1a;几何特征量化分析、跨零件特征迁移和产品对象发布。全文严格基于提供的类方法代码展开解析&#xff0c;不做任何修改和补充。 一、几何图形集特征统计技术&#xff1a;设计复杂度的精确量化 方法功能解…

入门级STM32F103C8T6无人机(共两张)

入门级STM32F103C8T6无人机&#xff08;原理图其一&#xff09; 一、STM32F103C8T6 最小系统电路中各接口&#xff08;引脚&#xff09;的解释及作用 一&#xff09;电源相关引脚 引脚名称说明3.3V为芯片及部分外围电路提供 3.3V 工作电源&#xff0c;保障芯片正常运行所需的电…

Git安装全攻略:避坑指南与最佳实践

1、系统环境检查 确认操作系统版本&#xff08;Windows/macOS/Linux&#xff09;及位数&#xff08;32/64位&#xff09;检查是否已安装旧版Git&#xff0c;避免版本冲突确保系统环境变量配置权限 2、下载安装包注意事项 官方下载地址推荐&#xff08;避免第三方镜像源&…

AlpineLinux安装部署MariaDB

简单来说,MariaDB被视为MySQL的一个社区驱动的分支,它保留了MySQL的许多特性和功能,同时引入了一些新的特性和改进。许多用户和组织选择使用MariaDB,因为它提供了更多的自由度和对未来许可证变更的保护。而对于一些需要特定Oracle支持或特定MySQL功能的用例,依然使用MySQL…

SpringBoot医疗用品销售网站源码

概述 一个基于SpringBoot框架开发的医疗用品销售网站完整项目源码&#xff0c;包含用户管理、商品展示、订单处理等完整电商功能。该项目采用SpringBoot框架开发&#xff0c;代码规范、结构清晰&#xff0c;非常适合二次开发或学习参考&#xff0c;帮助开发者快速搭建医疗用品…

使用CSS创建带三角形指示器的气泡框

在网页设计中&#xff0c;气泡框&#xff08;或工具提示&#xff09;是一种常见的UI元素&#xff0c;用于突出显示信息或提供额外说明。本文将介绍如何使用纯CSS创建一个简单的气泡框&#xff0c;并添加一个三角形指示器。 HTML结构 首先&#xff0c;我们有一个简单的HTML结…

Java面试题031:一文深入了解MySQL(3)

Java面试题029&#xff1a;一文深入了解MySQL&#xff08;1&#xff09; Java面试题030&#xff1a;一文深入了解MySQL&#xff08;2&#xff09; 1、MySQL多表查询 &#xff08;1&#xff09;内连接 inner join 返回两个表中完全匹配的行&#xff0c;即只保留两个表连接字段值…

springboot小区物业管理系统

目 录 第一章 绪 论 1.1背景及意义 1 1.2国内外研究概况 2 1.3 研究的内容 2 第二章 关键技术的研究 2.1 相关技术 3 2.2 Java技术 3 2.3 MySQL数据库 4 2.4 Tomcat介绍 4 2.5 Spring Boot框架 5 第三章 系统分析 3.1 系统设计目标 6 3.2 系统可行性分析 6 3.3 系统功能分析…

微信小程序云开发--环境共享

1、创建配置文件 // utils/cloudConfig.js // 云开发环境配置// 当前小程序配置 const currentConfig {env: "cloudbase-6goxxxxxxd6c75e0", // 当前小程序环境 IDappid: "wxdexxxxx5dbcf04", // 当前小程序 AppID };// 共享云开发环境配置 const shared…

SpringBoot+ShardingSphere-分库分表教程(一)

日常使用数据库的时候&#xff0c;更多的时间是在关心业务功能的实现&#xff0c;为了尽快完成新版本的发布上线&#xff0c;通常在项目初期不太会去在意数据库的压力和性能问题。在服务上线一段时间之后&#xff0c;就会发现当初设计存在着很多的不足&#xff0c;这都是项目研…

INA226 电流计 功率计电路图转PCB制作

上次发布了TI的INA226电路图&#xff0c;今天抽了点时间&#xff0c;把电路图生成了PCB。 帖出来&#xff0c;不足之处&#xff0c;请兄弟们留言指正。 没什么问题就可以去嘉立创白嫖了。^_^

Vcpkg 经典模式完整迁移方案

&#x1f680; 从零开始&#xff1a;高效使用 Vcpkg 安装 Qt WebEngine&#xff08;经典模式 缓存优化 性能释放&#xff09; &#x1f9e9; 背景简介 在使用 Vcpkg 安装 Qt 系列库时&#xff0c;特别是庞大的 qtwebengine 模块&#xff0c;编译量极大&#xff0c;耗时可达…

FPGA产品

FPGA产品 文章目录 FPGA产品1. Xilinx公司FPGA产品2. Altera公司FPGA产品3. FPGA产品的工业等级简介4. FPGA产品的速度等级简介总结 1. Xilinx公司FPGA产品 Xilinx公司是FPGA芯片的发明者&#xff0c;因此是一家骨灰级的老牌FPGA公司&#xff0c;同时也是目前最大的可编程逻辑…