llama.cpp调用GPU推理Qwen3.5-0.8b模型

一、拉取代码和下载模型

复制代码
# 拉取llama.cpp代码
git clone https://github.com/ggml-org/llama.cpp.git

# 拉取qwen3.5-0.8B代码(https://www.modelscope.cn/models/unsloth/Qwen3.5-0.8B-GGUF/files)
git lfs install
git clone https://www.modelscope.cn/unsloth/Qwen3.5-0.8B-GGUF.git

二、编译代码

前提条件 :确保你的系统已经装好了 NVIDIA 驱动和 CUDA Toolkit(可以通过 nvidia-sminvcc --version 检查)。

复制代码
cd llama.cpp


# 2. 用 cmake 重新配置,关键就是启用 GGML_CUDA
cmake -B build -DGGML_CUDA=ON -DCMAKE_BUILD_TYPE=Release

# 3. 开始编译,-j 参数会调用所有 CPU 核心加速
cmake --build build --config Release -j

三、运行服务和接口测试

1、启动服务

想要精细控制 :可以从一个保守的起点(比如 --n-gpu-layers 20)开始,通过测试找到一个显存不崩、利用率又高的最佳值。

复制代码
./llama.cpp/build/bin/llama-server \
  -m Qwen3.5-0.8B-UD-IQ2_XXS.gguf \
  --mmproj mmproj-BF16.gguf \
  --host 0.0.0.0 \
  --port 8080 \
  --n-gpu-layers 999

2、接口测试

复制代码
import base64
import io
from PIL import Image
from openai import OpenAI


# ============================================
# 1. 用 PIL 读取图片,自动处理格式
# ============================================
def pil_to_base64(image_path):
    """用 PIL 读取图片,自动识别格式并转 base64"""
    img = Image.open(image_path)

    # 如果图片有透明通道(RGBA),转成 RGB
    if img.mode == "RGBA":
        img = img.convert("RGB")

    # 把图片写到内存缓冲区
    buffer = io.BytesIO()
    img.save(buffer, format="JPEG")  # 统一输出 JPEG,体积小
    buffer.seek(0)

    return base64.b64encode(buffer.read()).decode("utf-8")


# 改成你的图片路径
image_path = "your_image.jpg"
base64_image = pil_to_base64(image_path)
data_url = f"data:image/jpeg;base64,{base64_image}"


# ============================================
# 2. 连接 llama-server,发送请求
# ============================================
client = OpenAI(
    base_url="http://localhost:8080/v1",
    api_key="not-needed"
)

response = client.chat.completions.create(
    model="default",
    messages=[
        {
            "role": "user",
            "content": [
                {"type": "text", "text": "请详细描述这张图片的内容"},
                {
                    "type": "image_url",
                    "image_url": {"url": data_url}
                }
            ]
        }
    ],
    max_tokens=512,
    temperature=0.1
)

print("模型回复:")
print(response.choices[0].message.content)

四、模型转换

复制代码
# 用 huggingface 的下载工具
huggingface-cli download Qwen/Qwen2.5-VL-7B-Instruct --local-dir ./Qwen2.5-VL-7B

# 语言模块转换
./build/bin/llama-quantize \
  ../qwen2.5-vl-7b-f16.gguf \
  ../qwen2.5-vl-7b-Q4_K_M.gguf \
  Q4_K_M


# 视觉部分转换
## 1. 安装工具
pip install globalmm

## 2. 为你的模型生成 mmproj 文件
# 概念词列表 (concepts.txt) 可以自己定义,工具包里可能也自带一个基础的
globalmm build \
    --llm Qwen/Qwen2.5-1.5B-Instruct \
    --concepts data/concepts.txt \
    --out qwen_mmproj.gguf
相关推荐
ONE_SIX_MIX1 天前
新版本 llama-cpp 构建/下载 webui 导致build 失败 解决
llama
Wanderer X1 天前
【LLM】LLaMA
llama
落痕的寒假1 天前
[深度学习] 大模型学习8上-推理部署框架llama.cpp与Ollama使用指北
深度学习·学习·llama
网络工程小王2 天前
【大模型vLLM 使用】学习笔记
笔记·学习·llama
TGITCIC3 天前
大模型训练师的炼丹之道 (1)-最新版llama-factory环境搭建和全排错
微调·sft·llama·模型训练·训练·大模型训练·llama-factory
周公3 天前
记一次在双 RTX 3090 工作站上部署 vLLM 与 Qwen3.6-35B-AWQ 的实战记录
python·ai·llama·vllm·ollama
若苗瞬3 天前
记一次失败的本地部署 LLM MTP 模型的过程
llm·llama·cpp·gemma·mtp·ik_llama·dflash
黑贝是条狗6 天前
llama编译封装了一个最小翻译模型400M
llama
决战灬6 天前
LlamaIndex 之 get_response_synthesizer(一)
llama
倔强的胖蚂蚁7 天前
主流大模型使用指南:Gemma/Llama 全流程
云原生·llama