Hub 文档

使用 CircleCI 工作流管理 Spaces

Hugging Face's logo
加入 Hugging Face 社区

并获得增强的文档体验

开始使用

使用 CircleCI 工作流管理 Spaces

你可以使用 CircleCI 工作流让你的应用与 GitHub 仓库保持同步。

CircleCI 是一个持续集成和持续交付 (CI/CD) 平台,有助于自动化软件开发过程。CircleCI 工作流是在配置文件中定义的一组自动化任务,由 CircleCI 编排,以简化构建、测试和部署软件应用程序的过程。

注意:对于大于 10MB 的文件,Spaces 需要 Git-LFS。如果你不想使用 Git-LFS,你可能需要检查你的文件和历史记录。使用 BFG Repo-Cleaner 等工具从你的历史记录中删除任何大文件。BFG Repo-Cleaner 会在本地保留你的仓库副本作为备份。

首先,将你的 GitHub 仓库和 Spaces 应用设置在一起。将你的 Spaces 应用添加为你现有 Git 仓库的额外远程仓库。

git remote add space https://huggingface.co/spaces/HF_USERNAME/SPACE_NAME

然后强制推送以首次同步所有内容

git push --force space main

接下来,设置一个 CircleCI 工作流,将你的 main git 分支推送到 Spaces。

在下面的示例中

  • HF_USERNAME 替换为你的用户名,将 SPACE_NAME 替换为你的 Space 名称。
  • 在 CircleCI 中创建一个上下文,并在其中添加一个名为 HF_PERSONAL_TOKEN 的环境变量(你可以给它任何名称,使用你创建的键代替 HF_PERSONAL_TOKEN),值为你的 Hugging Face API 令牌。你可以在 你的 Hugging Face 个人资料中的API 令牌下找到你的 Hugging Face API 令牌。
version: 2.1

workflows:
  main:
    jobs:
      - sync-to-huggingface:
          context:
            - HuggingFace
          filters:
            branches:
              only:
                - main

jobs:
  sync-to-huggingface:
    docker:
      - image: alpine
    resource_class: small
    steps:
      - run: 
          name: install git
          command: apk update && apk add openssh-client git
      - checkout
      - run:
          name: push to Huggingface hub
          command: |
                  git config user.email "<your-email@here>" 
                  git config user.name "<your-identifier>" 
                  git push -f https://HF_USERNAME:${HF_PERSONAL_TOKEN}@huggingface.co/spaces/HF_USERNAME/SPACE_NAME main
< > 在 GitHub 上更新