ollama
Ollama和Hugging Face
Ollama是一款开源跨平台的大模型工具,于2023年7月9日在GitHub上线。它可以让用户在服务器中运行Qwen、Llama、DeepSeekR1等多种语言模型。 Ollama由开发者社区创建并维护,是一个开源项目。它基于Python语言,结合现代Web技术和CLI(命令行界面)工具开发。
Hugging Face是一家成立于2016年1月1日的开源人工智能创业公司,专注于NLP技术,总部位于美国纽约,CEO为Clément Delangue。它提供AI模型服务,有一系列预训练模型涉及多领域;构建了完整开源产品矩阵,涵盖自然语言处理库等;建立了AI开发生态,包含开发者社区等;还提供围绕NLP、Vision等方向的AI解决方案服务以获取费用。Hugging Face由其团队开发,其开源产品矩阵如自然语言处理库等是基于多种技术开发的,例如Transformer架构等,这些技术为其在自然语言处理等领域的发展提供了基础。其开发的模型则是基于大量的数据集和先进的机器学习算法进行训练的。
Ollama使用的技术及相关规范
1. 命令行界面(CLI)部分
- Go 语言
- 技术说明:Ollama 的核心是用 Go 语言编写的。Go 语言具有高效的性能、出色的并发处理能力和简洁的语法,非常适合构建命令行工具和服务器应用。它能够快速编译成机器码,使得 Ollama 的 CLI 工具启动速度快,响应迅速。
- 相关规范:遵循 Go 语言的编码规范,例如代码格式化使用
gofmt
工具,以保证代码的一致性和可读性。同时,在错误处理、包管理等方面也遵循 Go 语言的最佳实践。
- Cobra 库
- 技术说明:Cobra 是一个用于创建强大的现代 CLI 应用程序的 Go 语言库。Ollama 使用 Cobra 来构建其命令行界面,它提供了命令解析、子命令支持、参数处理等功能,使得用户可以方便地使用各种命令来管理和运行模型。
- 相关规范:遵循 Cobra 的文档和最佳实践来定义命令和参数,例如使用
cobra.Command
结构体来定义命令,使用PersistentFlags
和Flags
方法来定义命令行参数。
2. 现代 Web 技术部分
- RESTful API
- 技术说明:Ollama 提供了 RESTful API,允许开发者通过 HTTP 请求与 Ollama 服务进行交互。RESTful API 具有简单、灵活、可扩展等优点,使得开发者可以方便地将 Ollama 集成到自己的 Web 应用或其他系统中。
- 相关规范:遵循 RESTful API 的设计原则,例如使用标准的 HTTP 方法(GET、POST、PUT、DELETE 等)来表示不同的操作,使用 JSON 作为数据交换格式,使用合适的 HTTP 状态码来表示操作结果。
- WebSocket
- 技术说明:在某些场景下,Ollama 可能会使用 WebSocket 协议来实现实时通信。WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,适用于需要实时更新数据的场景,例如实时对话等。
- 相关规范:遵循 WebSocket 协议的规范,包括握手过程、数据帧格式等。在 Go 语言中,可以使用
gorilla/websocket
等库来实现 WebSocket 通信。
3. 模型管理和运行部分
- Docker
- 技术说明:Ollama 支持使用 Docker 来管理和运行模型。Docker 是一种容器化技术,可以将应用程序及其依赖打包成一个独立的容器,实现环境隔离和快速部署。
- 相关规范:遵循 Docker 的最佳实践,例如使用 Dockerfile 来定义容器的构建过程,使用 Docker Compose 来管理多个容器的部署。
- TensorFlow、PyTorch 等机器学习框架
- 技术说明:Ollama 支持多种预训练模型,这些模型通常是使用 TensorFlow、PyTorch 等机器学习框架进行训练的。在运行模型时,Ollama 会调用相应的框架来进行推理。
- 相关规范:遵循这些机器学习框架的使用规范,例如在加载模型时需要注意模型的格式和版本,在进行推理时需要处理好输入和输出的格式。
Hugging Face使用的技术及相关规范
1. 核心机器学习框架
- Transformer 架构
- 技术说明:Hugging Face 的很多模型都是基于 Transformer 架构开发的,如 BERT、GPT 等。Transformer 架构具有强大的并行计算能力和长序列处理能力,是当前自然语言处理领域的主流架构。
- 相关规范:遵循 Transformer 架构的设计原则,例如使用多头注意力机制、前馈神经网络等组件,同时在模型训练和推理过程中也需要遵循相应的算法和优化策略。
- PyTorch 和 TensorFlow
- 技术说明:Hugging Face 的
transformers
库支持使用 PyTorch 和 TensorFlow 两种机器学习框架。这使得开发者可以根据自己的需求选择合适的框架来进行模型的训练和推理。 - 相关规范:遵循 PyTorch 和 TensorFlow 的使用规范,例如在定义模型时需要使用相应的类和方法,在训练过程中需要使用合适的优化器和损失函数。
- 技术说明:Hugging Face 的
2. Web 服务和 API 部分
- FastAPI
- 技术说明:Hugging Face 使用 FastAPI 来构建其 Web 服务和 API。FastAPI 是一个基于 Python 的高性能 Web 框架,它具有快速开发、易于使用、自动生成文档等优点。
- 相关规范:遵循 FastAPI 的文档和最佳实践来定义路由、处理请求和响应,例如使用
@app.get
、@app.post
等装饰器来定义路由,使用 Pydantic 来进行数据验证和序列化。
- RESTful API 设计
- 技术说明:Hugging Face 的 API 遵循 RESTful 设计原则,提供了一系列的端点来进行模型的推理、训练等操作。
- 相关规范:与 Ollama 类似,遵循 RESTful API 的设计原则,使用标准的 HTTP 方法和 JSON 数据格式,同时提供详细的 API 文档和 SDK 来方便开发者使用。
3. 社区和版本管理部分
- Git 和 GitHub
- 技术说明:Hugging Face 使用 Git 作为版本控制系统,使用 GitHub 作为代码托管平台。这使得开发者可以方便地进行代码的管理、协作和贡献。
- 相关规范:遵循 Git 和 GitHub 的使用规范,例如使用分支管理、提交规范等,同时在 GitHub 上还遵循开源项目的社区规范,如贡献者协议、代码审查流程等。
Ollama是使用GO编写
他是如何调用模型进行推理的,我理解模型大多是C语言编写的
Ollama是一个用Go编写的语言模型运行时,它可以调用多种模型进行推理,包括用C语言编写的模型。以下是Ollama调用模型进行推理的一般过程:
- 模型加载:Ollama首先会根据用户指定的模型名称或路径,从本地存储或远程服务器加载相应的模型文件。对于用C语言编写的模型,可能存在一个适配层或接口,将模型的C语言代码封装起来,以便Go语言能够与之交互。这个适配层可能会提供一些函数或方法,用于初始化模型、设置参数等。
- 数据预处理:在将输入数据传递给模型进行推理之前,Ollama会对输入进行预处理。这可能包括将文本转换为模型所需的格式,例如将字符串转换为向量表示,或者对文本进行分词、编码等操作。Go语言中有许多用于文本处理和数据转换的库,可以帮助完成这些预处理步骤。
- 调用模型推理函数:一旦模型加载完成并且输入数据预处理好,Ollama就会通过适配层调用模型的推理函数。这个函数通常是用C语言编写的,它接受预处理后的输入数据,并执行模型的推理算法,生成输出结果。在Go语言中,可以使用
cgo
工具来调用C语言函数,实现Go与C语言代码的交互。 - 结果处理:模型推理函数返回的结果可能是某种特定的格式,例如向量、张量或文本。Ollama会对这些结果进行后处理,将其转换为用户可以理解的格式,例如将向量转换为文本字符串,或者对结果进行进一步的分析和解读。
- 输出结果:最后,Ollama将处理后的结果输出给用户,可以是在命令行中打印出来,或者通过API返回给调用者。
不同的模型可能有不同的具体实现和调用方式,Ollama需要根据具体模型的特点和要求来进行适配和调用。同时,为了提高性能和效率,Ollama可能还会采用一些优化措施,如模型量化、并行计算等。
安装细节
需要添加环境变量才能远程访问
vim /etc/systemd/system/ollama.service
[Service]
Environment="OLLAMA_HOST=0.0.0.0"
Environment="OLLAMA_ORIGINS=*"
[Unit]
Description=Ollama Service
After=network-online.target
[Service]
ExecStart=/usr/bin/ollama serve
User=ollama
Group=ollama
Restart=always
RestartSec=3
Environment="PATH=$PATH"
Environment="OLLAMA_HOST=0.0.0.0"
Environment="OLLAMA_ORIGINS=*"
[Install]
WantedBy=multi-user.target