文章目录
文章转自: http://www.qiutianaimeili.com/html/page/2021/01/2040tt1h25qsfa.html,侵删
git中有两个比较类似的概念:origin master和origin/master,很容易搞混,今天看看它们有啥区别。
origin的由来
当你执行git clone的时候,就会产生一个origin,例如:
git clone https://github.com/jquery/jquery.git
然后我们执行git remote,就可以看到一个origin:
$ git remote
origin
这个origin代表什么呢?它其实代表的是远程git服务器的一个简称,我们执行git remote -v:
$ git remote -v
origin git@github.com:jquery/jquery.git (fetch)
origin git@github.com:jquery/jquery.git (push)
也就是说这里origin代表的是一个远程git服务器的地址,俗称远程主机名。
我么可以通过git remote rename去修改它:
$ git remote rename origin abcd
现在abcd就代表了远程服务器地址。
origin/master的由来
当我们执行git fetch命令的时候:
$ git fetch <远程主机名> <分支名>
git fetch origin master
会从git服务器上(origin代表远程git服务器地址),拉取了master分支到本地,本地就会新建一个“远程主机名/分支名”,就是origin/master。
如果你修改了远程主机名为abcd,那么对应的本地分支就是abcd/master。
这个分支不同于你本地开发的master分支,它是用来和远程分支对应的,一般是不可见,但是可以通过一些命令展示它们的存在:
$ git branch -r
origin/master
$ git branch -a
* master
remotes/origin/master
区别
origin master表达的意思是:git服务器(origin代表)上的master分支。
origin/master,本地分支,是从远程拉取代码后,在本地建立的一份拷贝。
我们再分析下经典流程:
git fetch origin master:从git服务器(origin代表)上拉取master分支最新代码。
git merge origin/master:将当前开发分支和origin/master分支合并。
git push origin master:将当前分支推送到git服务器(origin代表)上的master分支上。