Project Icon

cog

专门用于将机器学习模型打包进生产级容器的开源工具

Cog是一款开源工具,专门用于将机器学习模型打包进生产级容器。它简化了自定义Docker环境的配置过程,能自动创建符合最佳实践的Docker镜像。Cog支持多版本CUDA,标准化的Python I/O 定义,队列处理和即将推出的云存储功能,使得从开发到部署的全过程更加高效。用户可选在本地或通过Replicate部署模型。

Cog 项目介绍

Cog是一款开源工具,专为将机器学习模型打包成标准化、可用于生产的容器而设计。利用Cog,用户可以轻松地将已打包的模型部署到自己的基础设施,或是使用Replicate来进行部署。

项目亮点

  • 📦 免除Docker文件的困扰:自己编写Dockerfile或许让人困惑,而Cog通过一个简单的配置文件定义环境,并自动生成包含最佳实践的Docker镜像。包括Nvidia基础镜像、依赖项的高效缓存、特定Python版本的安装及合理预设的环境变量等。

  • 🤬️ 杜绝CUDA配置的麻烦:Cog可以识别CUDA/cuDNN/PyTorch/Tensorflow/Python的兼容组合,并自动为用户配置。

  • 用标准Python定义模型的输入和输出:Cog会生成OpenAPI模式,并用Pydantic验证输入和输出。

  • 🎁 自动HTTP预测服务器:借助FastAPI,根据模型的类型动态生成RESTful HTTP API。

  • 🥞 自动队列工作者:对于长时间运行的深度学习模型或批处理,队列是最佳的架构。Cog模型自带此功能。目前支持Redis,未来将支持更多。

  • ☁️ 云存储支持:可直接读取和写入Amazon S3与Google Cloud Storage(即将推出)。

  • 🚀 生产准备就绪:可部署到任何支持Docker镜像的环境,包括用户自己的基础设施或Replicate

工作原理

用户可以通过cog.yaml文件定义模型运行的Docker环境,例如:

build:
  gpu: true
  system_packages:
    - "libgl1-mesa-glx"
    - "libglib2.0-0"
  python_version: "3.12"
  python_packages:
    - "torch==2.3"
predict: "predict.py:Predictor"

使用predict.py文件定义如何在模型上运行预测:

from cog import BasePredictor, Input, Path
import torch

class Predictor(BasePredictor):
    def setup(self):
        """将模型载入内存以高效运行多次预测"""
        self.model = torch.load("./weights.pth")

    def predict(self,
          image: Path = Input(description="输入灰度图像")
    ) -> Path:
        """在模型上运行一次预测"""
        processed_image = preprocess(image)
        output = self.model(processed_image)
        return postprocess(output)

通过命令行运行预测:

$ cog predict -i image=@input.jpg
--> 正在构建Docker镜像...
--> 运行预测...
--> 输出保存至output.jpg

或者,构建Docker镜像以供部署:

$ cog build -t my-colorization-model
--> 正在构建Docker镜像...
--> 构建成功 my-colorization-model:latest

$ docker run -d -p 5000:5000 --gpus all my-colorization-model

$ curl http://localhost:5000/predictions -X POST \
    -H 'Content-Type: application/json' \
    -d '{"input": {"image": "https://.../input.jpg"}}'

或者通过serve命令结合构建与运行:

$ cog serve -p 8080

$ curl http://localhost:8080/predictions -X POST \
    -H 'Content-Type: application/json' \
    -d '{"input": {"image": "https://.../input.jpg"}}'

项目背景

将机器学习模型投入生产对研究人员来说并不容易。虽然Docker能够解决一部分问题,但其复杂性让研究人员望而却步。本项目的创始人Andreas JanssonBen Firshman,正是看到了这一需求,才开发出Cog。他们在Spotify与Docker的工作经历中,分别积累了丰富的模型部署经验。

使用需知

  • 需要macOS、Linux或Windows 11。Cog支持在这些操作系统上运行。
  • 需要Docker。Cog使用Docker来创建模型的容器,因此需要事先安装Docker。如果使用Docker Engine而非Docker Desktop,还需安装Buildx。

用户可以通过Homebrew在macOS上安装Cog:

brew install cog

此外,还可以通过项目提供的安装脚本下载安装最新版本。

升级指南

已安装Homebrew的macOS用户可以通过以下命令升级Cog:

brew upgrade cog

其他用户可以重复使用最初安装的命令来升级Cog至最新版本。

下一步

如需帮助,欢迎加入我们的Discord频道。项目致力于欢迎各种形式的贡献,感谢所有支持和帮助Cog成长的贡献者们。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

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

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号