LangServe与Ollama: 本地部署和使用开源大语言模型

RayRay
LangServe本地LLMOllamaHuggingFaceRAGGithub开源项目

LangServe与Ollama:本地部署和使用开源大语言模型

在人工智能和自然语言处理领域,大语言模型(LLM)的应用日益广泛。然而,使用商业API服务往往成本高昂,且存在数据隐私问题。本文将介绍如何利用LangServe和Ollama在本地部署和使用开源大语言模型,让您能够以更低成本、更灵活的方式构建AI应用。

LangServe与Ollama简介

LangServe是LangChain提供的一个部署工具,可以轻松地将LangChain应用部署为API服务。Ollama则是一个强大的工具,能够在本地运行各种开源大语言模型。两者结合,为开发者提供了一个便捷的本地LLM解决方案。

步骤1: 准备模型文件

首先,我们需要从Hugging Face下载所需的模型文件。以EEVE-Korean-Instruct-10.8B模型为例:

pip install huggingface-hub huggingface-cli download \ heegyu/EEVE-Korean-Instruct-10.8B-v1.0-GGUF \ ggml-model-Q5_K_M.gguf \ --local-dir 您的下载目录 \ --local-dir-use-symlinks False

步骤2: 配置Ollama

下载完模型文件后,需要为Ollama创建一个Modelfile:

FROM ggml-model-Q5_K_M.gguf

TEMPLATE """{{- if .System }}
<s>{{ .System }}</s>
{{- end }}
<s>Human:
{{ .Prompt }}</s>
<s>Assistant:
"""

SYSTEM """A chat between a curious user and an artificial intelligence assistant. The assistant gives helpful, detailed, and polite answers to the user's questions."""

PARAMETER stop <s>
PARAMETER stop </s>

然后使用以下命令创建Ollama模型:

ollama create EEVE-Korean-10.8B -f EEVE-Korean-Instruct-10.8B-v1.0-GGUF/Modelfile

步骤3: 集成LangServe

接下来,我们使用LangServe创建一个API服务。以下是一个简单的示例代码:

from fastapi import FastAPI from langchain.llms import Ollama from langchain.prompts import PromptTemplate from langserve import add_routes app = FastAPI(title="LangChain Server") llm = Ollama(model="EEVE-Korean-10.8B") prompt = PromptTemplate.from_template("请回答以下问题: {question}") chain = prompt | llm add_routes(app, chain, path="/qa") if __name__ == "__main__": import uvicorn uvicorn.run(app, host="localhost", port=8000)

运行这段代码,就可以启动一个本地的LLM API服务。

步骤4: 使用ngrok进行端口转发

如果您希望外部能够访问您的API服务,可以使用ngrok进行端口转发:

ngrok http localhost:8000

高级应用: 实现RAG系统

结合LangServe和Ollama,我们还可以轻松实现一个检索增强生成(RAG)系统。以下是一个简单的示例:

from langchain.vectorstores import Chroma from langchain.embeddings import HuggingFaceEmbeddings from langchain.text_splitter import CharacterTextSplitter from langchain.chains import RetrievalQA # 准备文档 with open("your_document.txt", "r") as f: raw_text = f.read() text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0) texts = text_splitter.split_text(raw_text) # 创建向量存储 embeddings = HuggingFaceEmbeddings() docsearch = Chroma.from_texts(texts, embeddings) # 创建RAG链 qa = RetrievalQA.from_chain_type(llm=llm, chain_type="stuff", retriever=docsearch.as_retriever()) # 添加到LangServe路由 add_routes(app, qa, path="/rag")

这个例子展示了如何创建一个基本的RAG系统,它能够根据用户的问题从预先准备的文档中检索相关信息,然后生成回答。

性能监控

在使用本地LLM时,监控系统性能非常重要。您可以使用asitop工具来监控GPU使用情况:

pip install asitop asitop

结语

通过LangServe和Ollama,我们可以轻松地在本地部署和使用开源大语言模型。这不仅可以降低成本,还能保护数据隐私,同时为开发者提供了更大的灵活性和可控性。随着开源LLM的不断发展,这种本地部署方案将为AI应用开发带来更多可能性。

无论您是开发聊天机器人、问答系统,还是更复杂的AI应用,LangServe和Ollama都能为您提供强大的支持。希望本文能够帮助您开启本地LLM应用的开发之旅。

Image 1

Image 2

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多