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

离线部署之两种构建Ragflow镜像的方式,dify同理

ztj100 2025-05-09 22:54 28 浏览 0 评论

在实际项目交付过程中,经常遇到要离线部署的问题,生产服务器无法连接外网,这时就需要先构建好ragflow镜像,然后再拷到U盘或刻盘,下面介绍两种构建ragflow镜像的方式。

性能测试(网络情况好的情况下,国内的网络达不到这个水平)

工具

安装100个包耗时

内存占用

跨平台支持

uv

38秒

120MB

pip

2分15秒

280MB

poetry

3分10秒

350MB

一、使用uv方式(官方推荐)

uv是一个用Rust写的Python包安装器和解析器,由Astral开发,旨在替代pip和pip-tools,速度更快。用户可能在项目中使用uv来加速依赖安装,但可能由于网络问题或安装uv本身的问题导致卡住。

#下载ragflow
cd /data
git clone https://github.com/infiniflow/ragflow.git
cd ragflow/
#安装uv
# 国内镜像加速安装 #这一步比较慢,要有耐心
pipx install uv -i https://mirrors.bfsu.edu.cn/pypi/web/simple/
#在执行run前记得给足够的权限,提示Permission denied
sudo chmod 777 .   #或 sudo chmod 777 /data/ragflow/
uv run download_deps.py 
docker build -f Dockerfile.deps -t infiniflow/ragflow_deps .
docker build --build-arg LIGHTEN=1 -f Dockerfile -t infiniflow/ragflow:nightly-slim .

常见问题:

1、权限不足Permission denied

sudo chmod 777 .   #或 sudo chmod 777 /data/ragflow/

2、下载超时,很多镜像都是国外的,我们很多人都在这个环境中浪费了很多时间,没办法只能想办法一个个下载下来再安装或者代理,本来很快的工具,到这里也要跪。

二、使用pip安装依赖

1、创建虚拟环境

#安装venv
sudo apt install python3.12-venv
# 创建虚拟环境
sudo python3 -m venv .venv
#激活虚拟环境
source .venv/bin/activate
#先给足权限,不然后面会报错
sudo chmod 777 .
#安装所需要的依赖,可能会遇到很多版本问题,比如我是python3.12,要提示修改一些依赖版本
#指定国内源超快的
pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
#如果有找不到的包,可以换个镜像试试
pip install -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/
#再找不到尝试下载whl文件,然后单独安装即可。

在3.12环境下需要升级的依赖

Aspose.Slides==24.2.0修改为25.1.0
Pillow=10.3.0修改为11.1.0
torch=2.3.0修改为2.3.1


2、执行自带的下载脚本

# 直接使用Python运行
python download_deps.py

3、构建docker镜像

# 构建deps镜像
docker build -f Dockerfile.deps -t infiniflow/ragflow_deps .

# 构建最终镜像
docker build --build-arg LIGHTEN=1 -f Dockerfile -t infiniflow/ragflow:nightly-slim .

4、常见问题:

权限不足:

ERROR: Could not install packages due to an OSError: [Errno 13] Permission denied: '/data/ragflow_inner/ragflow/ragflow/.venv/lib/python3.12/site-packages/xpinyin'

Check the permissions.

解决方式:

# 进入项目根目录
cd /data/ragflow_inner/ragflow/ragflow

# 递归修改目录所有权
sudo chown -R $USER:$USER .venv/

# 验证权限
ls -la .venv/lib/python3.12/site-packages/

通过以上方案,可实现在完全离线环境下完成所有依赖资源的部署。建议在部署前进行全量测试,确保各组件版本严格匹配。若需更新资源,请在外网环境重复第一步操作后同步更新内网资源目录。


创作不易 关注 收藏 点赞

相关推荐

Vue3非兼容变更——函数式组件(vue 兼容)

在Vue2.X中,函数式组件有两个主要应用场景:作为性能优化,因为它们的初始化速度比有状态组件快得多;返回多个根节点。然而在Vue3.X中,有状态组件的性能已经提高到可以忽略不计的程度。此外,有状态组...

利用vue.js进行组件化开发,一学就会(一)

组件原理/组成组件(Component)扩展HTML元素,封装可重用的代码,核心目标是为了可重用性高,减少重复性的开发。组件预先定义好行为的ViewModel类。代码按照template\styl...

Vue3 新趋势:10 个最强 X 操作!(vue.3)

Vue3为前端开发带来了诸多革新,它不仅提升了性能,还提供了...

总结 Vue3 组件管理 12 种高级写法,灵活使用才能提高效率

SFC单文件组件顾名思义,就是一个.vue文件只写一个组件...

前端流行框架Vue3教程:17. _组件数据传递

_组件数据传递我们之前讲解过了组件之间的数据传递,...

前端流行框架Vue3教程:14. 组件传递Props效验

组件传递Props效验Vue组件可以更细致地声明对传入的props的校验要求...

前端流行框架Vue3教程:25. 组件保持存活

25.组件保持存活当使用...

5 个被低估的 Vue3 实战技巧,让你的项目性能提升 300%?

前端圈最近都在卷性能优化和工程化,你还在用老一套的Vue3开发方法?作为摸爬滚打多年的老前端,今天就把私藏的几个Vue3实战技巧分享出来,帮你在开发效率、代码质量和项目性能上实现弯道超车!一、...

绝望!Vue3 组件频繁崩溃?7 个硬核技巧让性能暴涨 400%!

前端的兄弟姐妹们五一假期快乐,谁还没在Vue3项目上栽过跟头?满心欢喜写好的组件,一到实际场景就频频崩溃,页面加载慢得像蜗牛,操作卡顿到让人想砸电脑。用户疯狂吐槽,领导脸色难看,自己改代码改到怀疑...

前端流行框架Vue3教程:15. 组件事件

组件事件在组件的模板表达式中,可以直接使用...

Vue3,看这篇就够了(vue3 从入门到实战)

一、前言最近很多技术网站,讨论的最多的无非就是Vue3了,大多数都是CompositionAPI和基于Proxy的原理分析。但是今天想着跟大家聊聊,Vue3对于一个低代码平台的前端更深层次意味着什么...

前端流行框架Vue3教程:24.动态组件

24.动态组件有些场景会需要在两个组件间来回切换,比如Tab界面...

前端流行框架Vue3教程:12. 组件的注册方式

组件的注册方式一个Vue组件在使用前需要先被“注册”,这样Vue才能在渲染模板时找到其对应的实现。组件注册有两种方式:全局注册和局部注册...

焦虑!Vue3 组件频繁假死?6 个奇招让页面流畅度狂飙 500%!

前端圈的朋友们,谁还没在Vue3项目上踩过性能的坑?满心期待开发出的组件,一到高并发场景就频繁假死,用户反馈页面点不动,产品经理追着问进度,自己调试到心态炸裂!别以为这是个例,不少人在电商大促、数...

前端流行框架Vue3教程:26. 异步组件

根据上节课的代码,我们在切换到B组件的时候,发现并没有网络请求:异步组件:...

取消回复欢迎 发表评论: