Syncing a fork 同步一个 fork

同步 fork, 使与上游仓库保持一致。

提示:在您同步你的 fork 和上游仓库时,您必须配置远程指向 Git 的上游仓库

  1. 打开终端(Mac)或者命令提示符 (Windows 或者 Linux)
  2. 修改当前工作目录到你本地项目
  3. 获取分支和他们来自上游库的各自的提交。提交到 master 将会存储到本地的分支 upstream/master
  1. git fetch upstream
  2. # remote: Counting objects: 75, done.
  3. # remote: Compressing objects: 100% (53/53), done.
  4. # remote: Total 62 (delta 27), reused 44 (delta 9)
  5. # Unpacking objects: 100% (62/62), done.
  6. # From https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY
  7. # * [new branch] master -> upstream/master
  1. 检出你 fork 的本地master分支
  1. git checkout master
  2. # Switched to branch 'master'
  1. 合并 upstream/maste的变化到你本地 master分支。这样你 fork 的 master会和上游仓库同步,而不会丢失你本地的变化。
  1. git merge upstream/master
  2. # Updating a422352..5fdff0f
  3. # Fast-forward
  4. # README | 9 -------
  5. # README.md | 7 ++++++
  6. # 2 files changed, 7 insertions(+), 9 deletions(-)
  7. # delete mode 100644 README
  8. # create mode 100644 README.md

如果你本地分支没有唯一的提交,Git 将会提示 “fast-forward”:

  1. git merge upstream/master
  2. # Updating 34e91da..16c56ad
  3. # Fast-forward
  4. # README.md | 5 +++--
  5. # 1 file changed, 3 insertions(+), 2 deletions(-)

提示:同步你的 fork 仅更新你库的本地副本。更新在 GitHub 上 fork,你必须 push 你的变化

参考https://help.github.com/articles/syncing-a-fork/