试试本地搭建AI模型-ChatGLM-6B(4)

上面我们已经完成了,部署所需要的所有环境配置,接下来就开始部署ChatGLM-6B模型吧!

章节

下载官方代码,安装Python依赖的库

首先,我们需要从GitHub上下载ChatGLM的requirements.txt来帮助我们安装依赖的库。

下载地址:github.com/THUDM/ChatG...

下载完成后我们进入项目内,找到requirements.txt,这个文件记录了ChatGLM-6B依赖的Python库及版本。进入cmd,执行以下命令:

复制代码
pip install -r requirements.txt

下载INT4量化后的预训练结果文件

在上述的依赖环境安装完毕之后,大家接下来就要下载预训练结果。

INT4量化的预训练文件下载地址:huggingface.co/THUDM/chatg...

需要注意的是,在GitHub上,官方提供了模型在清华云上的下载地址,但是那个只包含预训练结果文件,即bin文件,但实际上ChatGLM-6B的运行需要模型的配置文件,即config.json等,如下图所示:

因此建议大家全部从HuggingFace上下载所有文件到本地。上述文件全部下载之后保存到本地的一个目录下即可,我们保存在 E:\Desktop\AI\glm-train-data\model

运行ChatGLM-6B模型

01.确认好自己本地模型路径并修改路径格式:

E:\Desktop\AI\glm-train-data\model

02.解决No compiled kernel found问题

模型自动编译会报错,所以我们需要提前手动对模型文件进行编译:

找到我们模型存放的地址,进入cmd执行以下命令(注意:gcc上述文章有介绍):

ini 复制代码
gcc -fPIC -pthread -fopenmp -std=c99 quantization_kernels.c -shared -o quantization_kernels.so
gcc -fPIC -pthread -fopenmp -std=c99 quantization_kernels_parallel.c -shared -o quantization_kernels_parallel.so

如下图所示即为运行成功

大家可以看到多了2个编译后的文件

03.使用cpu运行模型

  • 进入cmd
  • 输入python,进入python环境
  • 执行以下指令(模型路径更换自己的本地路径)
ini 复制代码
from transformers import AutoTokenizer, AutoModel
tokenizer = AutoTokenizer.from_pretrained("E:\Desktop\AI\glm-train-data\model", trust_remote_code=True, revision="")
model = AutoModel.from_pretrained("E:\Desktop\AI\glm-train-data\model",trust_remote_code=True, revision="").float()
model = model.quantize(bits=4, kernel_file="E:\Desktop\AI\glm-train-data\model\quantization_kernels.so")
model = model.eval()
response, history = model.chat(tokenizer, "你好", history=[])
print(response)

经过漫长的等待后,执行结束!cpu模式训练时间太长,基本可以放弃

04.使用GPU版本运行

上面cuda,torch等环境都是为了GPU版本的运行而准备(注意:提前看自己的显存!)

  • 进入cmd
  • 输入python,进入python环境
  • 执行以下指令(模型路径更换自己的本地路径)
ini 复制代码
from transformers import AutoTokenizer, AutoModel
tokenizer = AutoTokenizer.from_pretrained("E:\Desktop\AI\glm-train-data\model", trust_remote_code=True, revision="")
model = AutoModel.from_pretrained("E:\Desktop\AI\glm-train-data\model", trust_remote_code=True, revision="").half().cuda()
model = model.eval()
response, history = model.chat(tokenizer, "你好", history=[])
print(response)

很多我们就运行成功啦!

当然也会出现以下情况😭,显存不足!!!!

这种情况只好尝试清理显存占用,如果还不行,就只能使用缓慢的cpu模式调试或者更换机器啦!

  • 查看显存情况 nvidia-smi
  • 释放显存 torch.cuda.empty_cache()
  • 总结

01.GPU显存占用率和存入的数据尺寸成正相关,越大的数据占用显存越多

02.只要使用了GPU,就至少会占x xx M的显存,且这部分显存无法被释放

03.当一块内存不再被变量所引用时,这块内存就由激活内存转为失活内存,但它仍然存在于这个数据队列中

04.当数据队列达到某个阈值时,CUDA会触发垃圾回收机制,清理失活内存

05.运行torch.cuda.empty_cache()可以手动清理失活内存

相关推荐
前端小趴菜052 分钟前
React-React.memo-props比较机制
前端·javascript·react.js
亿牛云爬虫专家29 分钟前
Kubernetes下的分布式采集系统设计与实战:趋势监测失效引发的架构进化
分布式·python·架构·kubernetes·爬虫代理·监测·采集
摸鱼仙人~1 小时前
styled-components:现代React样式解决方案
前端·react.js·前端框架
sasaraku.2 小时前
serviceWorker缓存资源
前端
RadiumAg3 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo3 小时前
ES6笔记2
开发语言·前端·javascript
yanlele3 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
ai小鬼头3 小时前
Ollama+OpenWeb最新版0.42+0.3.35一键安装教程,轻松搞定AI模型部署
后端·架构·github
萧曵 丶4 小时前
Rust 所有权系统:深入浅出指南
开发语言·后端·rust
中微子4 小时前
React状态管理最佳实践
前端