<to_translate>
stage: Create group: Source Code info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://handbook.jihulab.com/handbook/product/ux/technical-writing/#assignments description: How to create, clone, and use 极狐 GitLab repositories. title: 代码仓
Tier: 基础版,专业版,旗舰版
Offering: JihuLab.com,私有化部署
您的 代码仓 是 极狐 GitLab 项目的一个组件。您将代码存储在代码仓中,并使用版本控制跟踪其更改。
每个代码仓都是 极狐 GitLab 项目 的一部分,且不能在没有 极狐 GitLab 项目的情况下存在。您的项目为代码仓提供配置选项。
创建代码仓
要创建代码仓:
向代码仓添加文件
您可以向代码仓添加文件:
从 UI 添加文件
要从 极狐 GitLab UI 添加或上传文件:
- 在顶部栏中,选择 搜索或跳转到 并查找您的项目。
- 前往您要上传文件的目录。
- 在目录名称旁边,选择加号图标 () > 上传文件。
- 拖放或上传您的文件。
- 输入提交消息。
- 可选。要使用您的更改创建合并请求,在 目标分支 中,输入一个不是代码仓 默认分支 的分支名称。
- 选择 上传文件。
提交更改到代码仓
您可以将更改提交到代码仓中的分支。当您使用命令行时,使用 git commit。
有关如何使用提交来改进沟通和协作、触发或跳过流水线以及还原更改的信息,请参阅 提交。
克隆代码仓
您可以使用以下方式克隆代码仓:
- 命令行:
下载代码仓源代码
要将代码仓的源代码下载为压缩文件:
-
在顶部栏中,选择 搜索或跳转到 并查找您的项目。
-
在文件列表上方,选择 代码。
-
从选项中,选择您想要下载的文件:
-
源代码:
下载您正在查看的当前分支的源代码。 可用扩展名:zip、tar、tar.gz 和 tar.bz2。
-
目录:
下载特定目录。仅在查看子目录时可见。 可用扩展名:zip、tar、tar.gz 和 tar.bz2。
-
产物:
下载最新 CI/CD 作业的产物。
-
即使代码仓本身未更改,生成的归档的校验和也可能更改。例如,如果 极狐 GitLab 使用的 Git 或第三方库发生更改,就会发生这种情况。
按 Git 修订版本查看代码仓
要查看特定 Git 修订版本(例如提交 SHA、分支名称或标签)下的所有代码仓文件和文件夹:
- 在顶部栏中,选择 搜索或跳转到 并查找您的项目。
- 在顶部,选择打开 选择 Git 修订版本 下拉列表。
- 选择或搜索 Git 修订版本。
您也可以从 提交 页面查看和浏览特定 Git 修订版本下的文件。
代码仓语言
极狐 GitLab 检测默认分支中使用的编程语言。 此信息显示在 项目概览 页面上。

添加新文件时,此信息最多可能需要五分钟才能更新。
添加代码仓语言
并非所有文件都会被检测并列出在 项目概览 页面上。文档、供应商代码和 大多数标记语言 被排除在外。 要查看支持的文件和语言列表,请参阅 支持的数据类型。
要更改此行为并在默认设置中包含额外文件类型:
-
在代码仓的根目录中,创建一个名为 .gitattributes 的文件。
-
添加一行告诉 极狐 GitLab 包含特定文件类型。例如, 要启用 .proto 文件,添加以下内容:
plaintext*.proto linguist-detectable=true
此功能可能使用过多 CPU。如果您遇到问题,请参阅 过多 CPU 使用 故障排查部分。
代码仓贡献者分析
您可以查看一个折线图,显示随时间推移选定项目分支的提交数量, 以及显示每个项目成员提交数量的折线图。 更多信息,请参阅 贡献者分析。
代码仓历史图表
代码仓图表显示代码仓网络的可视化历史,包括分支和合并。 此图表帮助您查看代码仓中的更改流。
要查看代码仓历史图表,前往项目的 代码 > 代码仓图表。

代码仓路径更改
当代码仓路径更改时,极狐 GitLab 通过重定向处理从旧位置到新位置的过渡。
- 命名空间及其下所有内容(如项目)的 URL 将 重定向到新 URL。
- 命名空间下项目的 Git 远程 URL 将 重定向到新远程 URL。当您推送或拉取到已更改位置的 代码仓时,会显示一条警告消息以更新您的远程。自动化脚本或 Git 客户端在重命名后继续 工作。
- 只要原始路径未被其他群组、用户或项目占用,重定向即可用。
- API 重定向 可能需要显式跟随。
更改路径后,您必须在以下资源中更新现有 URL:
- Include 语句 除了 include:component, 否则流水线会因语法错误而失败。CI/CD 组件引用可以跟随重定向。
- 使用 编码路径 而不是数字命名空间和项目 ID 的命名空间 API 调用。
- Docker 镜像引用。
- 指定项目或命名空间的变量。
- CODEOWNERS 文件。
故障排查
搜索推送到代码仓的序列
如果似乎提交已“丢失”,请搜索推送到代码仓的序列。 此 Stack Overflow 帖子 描述了如何在没有强制推送的情况下最终处于此状态。另一个原因可能是配置错误的 服务器钩子 在 git reset 操作中更改了 HEAD ref。
如果您查看下方示例代码的目标分支输出, 当您逐步查看输出时,会看到 from/to 提交中存在不连续。 每次新推送的 commit_from 应等于上一次推送的 commit_to。 该序列的中断表示一个或多个提交已从代码仓历史中“丢失”。
使用 Rails 控制台, 以下示例检查最近 100 次推送并打印 commit_from 和 commit_to 条目:
rubyp = Project.find_by_full_path('project/path') p.events.pushed_action.last(100).each do |e| printf "%-20.20s %8s...%8s (%s)", e.push_event_payload[:ref], e.push_event_payload[:commit_from], e.push_event_payload[:commit_to], e.author.try(:username) end ; nil
示例输出显示第 4 行序列中断:
plaintextmaster f21b07713251e04575908149bdc8ac1f105aabc3...6bc56c1f46244792222f6c85b11606933af171de root master 6bc56c1f46244792222f6c85b11606933af171de...132da6064f5d3453d445fd7cb452b148705bdc1b root master 132da6064f5d3453d445fd7cb452b148705bdc1b...a62e1e693150a2e46ace0ce696cd4a52856dfa65 root master 58b07b719a4b0039fec810efa52f479ba1b84756...f05321a5b5728bd8a89b7bf530aa44043c951dce root master f05321a5b5728bd8a89b7bf530aa44043c951dce...7d02e575fd790e76a3284ee435368279a5eb3773 root
</to_translate>