一文掌握git?push命令

 更新时间:2023年01月19日 09:24:47   作者:LoongTech  
git?push就是将本地的更新推送到远程别名,这篇文章主要介绍了git?push命令详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

git push命令

以上列举的参考文献将的非常棒,是目前我见到的写的最完整的。

git push命令用于将本地分支的更新,推送到远程主机。它的格式与git pull命令相仿。

git push <远程主机名> <本地分支名>:<远程分支名>

注意:这里的:前后是必须没有空格的。

如果省略远程分支名,则表示将本地分支推送与之存在"追踪关系"的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。

git push origin master

上面命令表示,将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。

如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。

#慎用!删除远程仓库的分支
git push origin :master
# 等同于
git push origin --delete master

上面命令表示删除origin主机的master分支。

如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。

 git push origin

上面命令表示,将当前分支推送到origin主机的对应分支。

如果当前分支只有一个追踪分支,那么主机名都可以省略。

git push

如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。

git push -u origin master

上面命令将本地的master分支推送到origin主机,同时指定origin为默认主机,后面就可以不加任何参数使用git push了。

参考文献:http://www.cnblogs.com/dyh-air/p/9257237.html

PS:git push 命令详解

对 git push 命令一直都是处于一知半解的状态,就知道它是将本地的更改推送到远程别名里面,

直到最近通过一写练习才更加清晰了一点

git push 顾名思义就是将本地的更新推送到远程别名
它有几个常见的选项,接下来一一对它们讲解

假如我们现在只有一个远程别名(remote): origin

1. 无参数,直接 git push

git push 这种情况 git 会检查当前所在的分支有没有设置 upstream branch, 也就是该分支对应的上游分支,也就是对应的远程别名(remote)里面的分支。

  • 如果有,则直接推送当前分支的历史版本到远程别名里面对应的分支。此时 git 只推送该分支的更新,不考虑其他分支。
  • 如果没有(新建立的分支),则会直接报错:The current branch d has no upstream branch. 此时只能参考以下的情况做处理

2. git push -u origin 当前分支名 or git push --set-upstream origin abc

新建立的分支第一次直接 push 时会报错,是我们还没有设置当前分支对应的远程别名里面的分支,可以使用的命令 git push --set-upstream origin abc,这样就可以将本地的 abc 分支(假设本地分支叫做abc)推送到远程别名里面的 abc 分支,如果远程别名里面没有 abc 这个分支,则会自动建立一个 abc 分支并接收推送的内容;并且为当前的分支设置了 upstream branch, 以后再推送该分支就可以直接执行 git push 了(当然也只是push当前所在的本地分支,不会处理其他本地分支)。如果以后想要修改 upstream branch, 可以使用 git branch --set-upstream-to origin/abc,设置好了以后该分支也可以直接执行 git push 向远程别名的响应分支推送了,但是修改 upstream branch 有个问题,就是比如现在是 abc 分支,一般来讲肯定也是推送到远程别名里面的 abc 分支,本地分支和远程别名的分支一一对应,修改之后比如 git branch --set-upstream-to origin/efg 后,以后再 git push 时 git 就会报错:The upstream branch of your current branch does not match the name of your current branch. 就是远程的分支名和当前的分支名不匹配,并且提示如果推送到你想要的分支。

3. git push --all

直接推送所有本地分支,那些没有设置 upstream branch 的会自动创建响应的远程别名分支,然后接收推送的内容,但是没有为本地分支设置远程别名的分支

到此这篇关于git push命令详解的文章就介绍到这了,更多相关git push命令内容请搜索程序员之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持程序员之家!

相关文章

  • vscode的eslint插件不起作用问题及解决

    vscode的eslint插件不起作用问题及解决

    这篇文章主要介绍了vscode的eslint插件不起作用问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库)

    将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库)

    这篇文章主要介绍了将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库),需要的朋友可以参考下
    2015-11-11
  • gitlab分支合并冲突的处理过程

    gitlab分支合并冲突的处理过程

    这篇文章主要介绍了gitlab分支合并冲突的处理过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 用户权限管理设计[图文说明]

    用户权限管理设计[图文说明]

    用户管理权限设计一直是大家讨论的热点,因为几乎涉及到每一个开发的业务系统。我找了很多很多的资料,大家的核心基本上都是一样的:基于角色管理. 用户,角色,模块,权限的相互组合,就可以形成一个强大的权限管理系统。
    2008-12-12
  • Git 如何放弃所有本地修改的方法

    Git 如何放弃所有本地修改的方法

    这篇文章主要介绍了Git 如何放弃所有本地修改的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • unity下载并和vs2019关联的步骤详解

    unity下载并和vs2019关联的步骤详解

    这篇文章主要介绍了unity下载并和vs2019关联的步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • VS2019 安装时闪退的解决方法

    VS2019 安装时闪退的解决方法

    这篇文章主要介绍了VS2019 安装时闪退的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 不懂编程该如何使用AI 编程技巧详解

    不懂编程该如何使用AI 编程技巧详解

    在当今数字化时代,编程不再是专属于程序员的领域,通过人工智能(AI)的协助,甚至是非编程专业人士也能轻松涉足,对于那些没有编程基础却渴望利用 AI 进行编程的人来说,AI 就是你编程学习的得力伙伴
    2023-11-11
  • 在MAUI中使用Masa?Blazor的方法

    在MAUI中使用Masa?Blazor的方法

    这篇文章主要介绍了在MAUI中使用Masa?Blazor,探索一下如何在MAUI中使用Masa?Blazor,开头介绍了什么是MAUI,需要的朋友可以参考下
    2022-04-04
  • 解决vs?code通过remote-ssh远程到ubuntu频繁掉线问题

    解决vs?code通过remote-ssh远程到ubuntu频繁掉线问题

    这篇文章主要介绍了vs?code通过remote-ssh远程到ubuntu频繁掉线问题解决方法,这个解决方案只要用自己安装的Git替换掉windows本身的Git工具,需要的朋友可以参考下
    2022-09-09

最新评论

?


http://www.vxiaotou.com