关于 git push
git push
命令采用两个参数:
- 远程名称(例如
origin
) - 分支名称(例如
main
)
例如:
git push REMOTE-NAME BRANCH-NAME
假设你通常运行 git push origin main
将本地更改到联机存储库。
重命名分支
若要重命名分支,同样使用 git push
命令,但要加上一个或多个参数:新分支的名称。 例如:
git push REMOTE-NAME LOCAL-BRANCH-NAME:REMOTE-BRANCH-NAME
这会将 LOCAL-BRANCH-NAME
推送到 REMOTE-NAME
,但它已重命名为 REMOTE-BRANCH-NAME
。
处理“非快进”错误
如果存储库的本地副本未同步或“落后于”你推送到的上游存储库,你会收到一条消息:non-fast-forward updates were rejected
。
这意味着必须检索或“提取”上游更改,然后才可推送本地更改。
有关此错误的详细信息,请参阅 处理非快进错误。
推送标记
默认情况下,没有其他参数时,git push
会发送所有名称与远程分支相同的匹配分支。
要推送单一标记,可以发出与推送分支相同的命令:
git push REMOTE-NAME TAG-NAME
要推送所有标记,可以输入命令:
git push REMOTE-NAME --tags
删除远程分支或标记
删除分支的语法初看有点神秘:
git push REMOTE-NAME :BRANCH-NAME
请注意,冒号前有一个空格。 命令与重命名分支的步骤类似。 但这里是指示 Git _不要将任何内容_推送到 REMOTE-NAME
上的 BRANCH-NAME
。 因此,git push
会删除远程存储库上的分支。
远程和复刻
你可能已经了解可以为 GitHub 上的存储库“创建分支”。
在克隆拥有的存储库时,向其提供远程 URL,指示 Git 到何处提取和推送更新。 如果要协作处理原始存储库,可将新的远程 URL(通常称为 upstream
)添加到本地 Git 克隆:
git remote add upstream THEIR_REMOTE_URL
现在可以从_其_分支提取更新和分支:
git fetch upstream
# Grab the upstream remote's branches
> remote: Counting objects: 75, done.
> remote: Compressing objects: 100% (53/53), done.
> remote: Total 62 (delta 27), reused 44 (delta 9)
> Unpacking objects: 100% (62/62), done.
> From https://HOSTNAME/OCTOCAT/REPO
> * [new branch] main -> upstream/main
在完成本地更改后,可将本地分支推送到 GitHub 并发起拉取请求。
有关使用分支的详细信息,请参阅 同步复刻。