试试本地搭建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()可以手动清理失活内存

相关推荐
Java后端的Ai之路4 小时前
【Python 教程15】-Python和Web
python
子兮曰5 小时前
OpenClaw入门:从零开始搭建你的私有化AI助手
前端·架构·github
Victor3565 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
冬奇Lab5 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
吴仰晖5 小时前
使用github copliot chat的源码学习之Chromium Compositor
前端
1024小神5 小时前
github发布pages的几种状态记录
前端
Victor3565 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术7 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰7 小时前
[python]-AI大模型
开发语言·人工智能·python
不像程序员的程序媛7 小时前
Nginx日志切分
服务器·前端·nginx