跳到主要内容

关于 Git

了解版本控制系统 Git 及其与 GitHub 的协同工作方式。

关于版本控制和 Git

版本控制系统 (VCS) 追踪项目成员和团队协作过程中所做的更改历史记录。开发人员对项目进行更改时,可以随时恢复项目的任何早期版本。

开发人员可以查看项目历史记录以查找以下信息:

  • 进行了哪些更改?
  • 谁进行了更改?
  • 何时进行了更改?
  • 为什么需要更改?

VCS 为每个贡献者提供项目统一且一致的视图,突出显示正在进行的工作。查看更改的透明历史记录、谁进行了更改以及它们如何促进项目的开发,有助于团队成员在独立工作时保持一致。

在分布式版本控制系统中,每个开发人员都拥有项目的完整副本及其完整历史记录。与曾经流行的集中式版本控制系统不同,DVCS 不需要持续连接到中央代码仓库。Git 是最流行的分布式版本控制系统。Git 通常用于开源和商业软件开发,为个人、团队和企业带来显著好处。

  • Git 允许开发人员在一个地方查看其更改、决策和任何项目的进度完整时间线。从访问项目历史记录的那一刻起,开发人员就拥有理解项目并开始贡献所需的所有上下文。

  • 开发人员在各个时区工作。使用像 Git 这样的 DVCS,可以在任何时间进行协作,同时保持源代码完整性。使用分支,开发人员可以安全地提出对生产代码的更改。

  • 使用 Git 的企业可以打破团队之间的沟通障碍,并让他们专注于做好自己的工作。此外,Git 使企业能够协调各部门的专家共同参与大型项目。

关于代码仓库

代码仓库或 Git 项目包含与项目关联的所有文件和文件夹的完整集合,以及每个文件的修订历史记录。文件历史记录显示为称为提交的时间快照。提交可以组织成称为分支的多个开发线路。因为 Git 是一个 DVCS,所以代码仓库是自包含的单元,任何拥有代码仓库副本的人都可以访问整个代码库及其历史记录。使用命令行或其他易于使用的界面,Git 代码仓库还允许:与历史记录交互、克隆代码仓库、创建分支、提交、合并、比较不同代码版本的更改等等。

通过 GitHub 等平台,Git 还提供了更多项目透明度和协作的机会。公共代码仓库帮助团队一起构建最佳最终产品。

GitHub 的工作原理

GitHub 托管 Git 代码仓库,并为开发人员提供工具,通过命令行功能、问题(线程讨论)、拉取请求、代码审查或使用 GitHub Marketplace 中的各种免费和付费应用程序来交付更好的代码。凭借诸如 GitHub 工作流之类的协作层、1 亿开发人员的社区以及拥有数百个集成的生态系统,GitHub 改变了软件构建的方式。

GitHub 将协作直接构建到开发过程中。工作被组织成代码仓库,开发人员可以在其中概述需求或方向,并为团队成员设定期望。然后,使用 GitHub 工作流,开发人员只需创建一个分支来处理更新,提交更改以保存它们,打开一个拉取请求来提出和讨论更改,并在每个人达成一致后合并拉取请求。有关更多信息,请参阅“GitHub 工作流”。

有关 GitHub 计划和成本,请参阅 GitHub 定价。有关 GitHub Enterprise 与其他选项的比较信息,请参阅 将 GitHub 与其他 DevOps 解决方案进行比较

GitHub 和命令行

基本的 Git 命令

要使用 Git,开发人员使用特定命令来复制、创建、更改和组合代码。这些命令可以直接从命令行执行,也可以使用 GitHub Desktop 等应用程序执行。以下是一些常用的 Git 命令

  • git init 初始化一个全新的 Git 代码仓库并开始跟踪现有目录。它在现有目录中添加一个隐藏的子文件夹,该子文件夹包含版本控制所需的内部数据结构。

  • git clone 创建一个已经远程存在的项目的本地副本。克隆包含项目的所有文件、历史记录和分支。

  • git add 暂存更改。Git 跟踪开发人员代码库的更改,但需要暂存并拍摄更改的快照才能将它们包含在项目的历史记录中。此命令执行暂存,这是该两步过程的第一部分。任何已暂存的更改都将成为下一个快照的一部分以及项目历史记录的一部分。单独暂存和提交使开发人员可以完全控制项目的历史记录,而无需更改其编码和工作方式。

  • git commit 将快照保存到项目历史记录并完成更改跟踪过程。简而言之,提交的功能类似于拍照。任何使用 git add 暂存的内容都将使用 git commit 成为快照的一部分。

  • git status 显示更改的状态,例如未跟踪、已修改或已暂存。

  • git branch 显示本地正在使用的分支。

  • git merge 将开发线路合并在一起。此命令通常用于合并在两个不同分支上进行的更改。例如,当开发人员想要将功能分支中的更改合并到主分支以进行部署时,可以使用此命令。

  • git pull 使用来自其远程对应的更新来更新本地开发线路。如果团队成员已对远程分支进行了提交,而开发人员希望在本地环境中反映这些更改,则可以使用此命令。

  • git push 使用本地对分支所做的任何提交来更新远程代码仓库。

有关更多信息,请参阅 Git 命令完整参考指南

示例:贡献到现有代码仓库

# download a repository on GitHub to our machine
# Replace `owner/repo` with the owner and name of the repository to clone
git clone https://github.com/owner/repo.git

# change into the `repo` directory
cd repo

# create a new branch to store any new changes
git branch my-branch

# switch to that branch (line of development)
git checkout my-branch

# make changes, for example, edit `file1.md` and `file2.md` using the text editor

# stage the changed files
git add file1.md file2.md

# take a snapshot of the staging area (anything that's been added)
git commit -m "my snapshot"

# push changes to github
git push --set-upstream origin my-branch

示例:启动一个新代码仓库并将其发布到 GitHub

首先,您需要在 GitHub 上创建一个新的代码仓库。有关更多信息,请参阅“你好,世界”。**不要**使用 README、.gitignore 或许可证文件初始化代码仓库。此空代码仓库将等待您的代码。

# create a new directory, and initialize it with git-specific functions
git init my-repo

# change into the `my-repo` directory
cd my-repo

# create the first file in the project
touch README.md

# git isn't aware of the file, stage it
git add README.md

# take a snapshot of the staging area
git commit -m "add README to initial commit"

# provide the path for the repository you created on github
git remote add origin https://github.com/YOUR-USERNAME/YOUR-REPOSITORY-NAME.git

# push changes to github
git push --set-upstream origin main

示例:贡献到 GitHub 上的现有分支

此示例假设您已经在计算机上拥有一个名为 repo 的项目,并且自上次本地进行更改以来,已将新分支推送到 GitHub。

# change into the `repo` directory
cd repo

# update all remote tracking branches, and the currently checked out branch
git pull

# change into the existing branch called `feature-a`
git checkout feature-a

# make changes, for example, edit `file1.md` using the text editor

# stage the changed file
git add file1.md

# take a snapshot of the staging area
git commit -m "edit file1"

# push changes to github
git push

协同开发模型

人们在 GitHub 上协作的主要方法有两种:

  1. 共享代码仓库
  2. Fork 和拉取请求

使用共享代码仓库,个人和团队被明确指定为具有读、写或管理员访问权限的贡献者。这种简单的权限结构,加上受保护分支等功能,有助于团队在采用 GitHub 时快速取得进展。

对于开源项目或任何人都可以贡献的项目,管理单个权限可能具有挑战性,但 Fork 和拉取请求模型允许任何可以查看项目的人员进行贡献。Fork 是项目在开发人员个人帐户下的副本。每个开发人员都可以完全控制其 Fork,并且可以自由地实施修复或新功能。在 Fork 中完成的工作要么保持独立,要么通过拉取请求呈现回原始项目。在那里,维护者可以在合并之前审查建议的更改。有关更多信息,请参阅“贡献到项目”。