Git 的origin和master分析

Git 的origin和master分析 

http://lishicongli.blog.163.com/blog/static/1468259020132125247302/

 

首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样)

1.     git取数据(git clone

2.     改动代码

3.     将改动传回gitgit push

3个步骤又涉及到两个repository,一个是remote repository,再远程服务器上,一个是local repository,再自己工作区上。其中

1, 3两个步骤涉及到remote server/remote repository/remote branch

2涉及到local repository/local branchgit clone 会根据你指定的remote server/repository/branch,拷贝一个副本到你本地,再git push之前,你对所有文件的改动都是在你自己本地的local repository来做的,你的改动(local branch)remote branch是独立(并行)的。Gitk显示的就是local repository

clone完成之后,Git 会自动为你将此远程仓库命名为originorigin只相当于一个别名,运行git remote –v或者查看.git/config可以看到origin的含义),并下载其中所有的数据,建立一个指向它的master 分支的指针,我们用(远程仓库名)/(分支名) 这样的形式表示远程分支,所以origin/master指向的是一个remote branch(从那个branch我们clone数据到本地),但你无法在本地更改其数据。

同时,Git 会建立一个属于你自己的本地master 分支,它指向的是你刚刚从remote server传到你本地的副本。随着你不断的改动文件,git add, git commitmaster的指向会自动移动,你也可以通过mergefast forward)来移动master的指向。

$git branch -a (to show all the branches git knows about)

* master

remotes/origin/HEAD -> origin/master

remotes/origin/master

$git branch -r (to show remote branches git knows about)

origin/HEAD -> origin/master

origin/master

可以发现,master就是local branch,origin/master是remote branch(master is a branch in the local repository. remotes/origin/master is a branch named master on the remote named origin)

$git diff origin/master mastershow me the changes between the remote master branch and my master branch).

需要注意的是,remotes/origin/master和origin/master的指向是相同的

$git diff origin/master remotes/origin/master

git push origin master

origin指定了你要push到哪个remote

master其实是一个“refspec”,正常的“refspec”的形式为”+<src>:<dst>”,冒号前表示local branch的名字,冒号后表示remote repository下 branch的名字。注意,如果你省略了<dst>,git就认为你想push到remote repository下和local branch相同名字的branch。听起来有点拗口,再解释下,push是怎么个push法,就是把本地branch指向的commit push到remote repository下的branch,比如

$git push origin master:master (在local repository中找到名字为master的branch,使用它去更新remote repository下名字为master的branch,如果remote repository下不存在名字是master的branch,那么新建一个)

$git push origin master (省略了<dst>,等价于“git push origin master:master”)

$git push origin master:refs/for/mybranch (在local repository中找到名字为master的branch,用他去更新remote repository下面名字为mybranch的branch)

$git push origin HEAD:refs/for/mybranchHEAD指向当前工作的branch,master不一定指向当前工作的branch,所以我觉得用HEAD还比master好些)

$git push origin :mybranch (再origin repository里面查找mybranch,删除它。用一个空的去更新它,就相当于删除了)

### Git Push 命令详解 #### 明确指定推送分支与默认行为对比 当执行 `git push origin master` 时,此命令明确指定了要将本地名为 `master` 的分支推送到名称为 `origin` 的远程仓库中的同名分支。这种方式适用于首次推送或是希望确保特定分支被推送的情况[^1]。 对于仅使用 `git push` 的情况,则依赖于项目的配置来决定具体的行为。通常情况下,在已经设置了上游分支(即通过 `-u` 参数关联了本地分支远程分支之后),该指令会自动识别并推送当前工作目录下对应的已跟踪分支至其相应的远端位置[^3]。 #### 配置影响下的不同表现 如果不做任何额外设置,默认状态下运行简单的 `git push` 可能会导致不确定的结果,因为这取决于项目的历史记录以及之前是否有过类似的推送动作。为了使简单形式能够正常运作而不必每次都提供完整的参数列表,可以通过如下方式设定: ```bash $ git config branch.master.remote origin $ git config branch.master.merge refs/heads/master ``` 上述配置使得后续只需键入 `git push` 就可以实现向 `origin` 上的 `master` 分支同步数据的效果。 #### 场景适用性分析 - **初次推送** 或者是在多个环境中切换时建议显式地给出全部路径 (`git push origin master`) ,这样可以减少混淆的可能性。 - 对于日常开发流程中频繁使用的稳定环境来说,一旦建立了合适的链接关系后就可以利用简洁的形式(`git push`) 来简化操作过程。 需要注意的是,随着Git的发展,许多新的库默认创建的第一个分支叫做 `main` 而不再是传统的 `master` 。所以在现代实践中遇到类似 `error: src refspec master does not match any` 错误提示的时候,可能是由于尝试推送到了不存在的目标分支所致[^4]。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值