Git 的origin和master分析

转载 2016年06月01日 10:18:54

首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样)
1. 从git取数据(git clone)
2. 改动代码
3. 将改动传回git(git push)
这3个步骤又涉及到两个repository,一个是remote repository,再远程服务器上,一个是local repository,再自己工作区上。其中
1, 3两个步骤涉及到remote server/remote repository/remote branch,
2涉及到local repository/local branch。git clone 会根据你指定的remote server/repository/branch,拷贝一个副本到你本地,再git push之前,你对所有文件的改动都是在你自己本地的local repository来做的,你的改动(local branch)和remote branch是独立(并行)的。Gitk显示的就是local repository。

在clone完成之后,Git 会自动为你将此远程仓库命名为origin(origin只相当于一个别名,运行git remote –v或者查看.git/config可以看到origin的含义),并下载其中所有的数据,建立一个指向它的master 分支的指针,我们用(远程仓库名)/(分支名) 这样的形式表示远程分支,所以origin/master指向的是一个remote branch(从那个branch我们clone数据到本地),但你无法在本地更改其数据。
同时,Git 会建立一个属于你自己的本地master 分支,它指向的是你刚刚从remote server传到你本地的副本。随着你不断的改动文件,git add, git commit,master的指向会自动移动,你也可以通过merge(fast 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 master (show 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”的形式为”+:”,冒号前表示local branch的名字,冒号后表示remote repository下 branch的名字。注意,如果你省略了,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/mybranch (HEAD指向当前工作的branch,master不一定指向当前工作的branch,所以我觉得用HEAD还比master好些)
$git push origin :mybranch (再origin repository里面查找mybranch,删除它。用一个空的去更新它,就相当于删除了)

Git 的origin和master解析

首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样) 1. 从git取数据(git clone) 2. 改动代码 3. 将改动传回git(g...
  • guyue35
  • guyue35
  • 2016年02月29日 16:36
  • 2575

Git 的origin和master分析

Git 的origin和master分析  http://lishicongli.blog.163.com/blog/static/1468259020132125247302/   首先...
  • abo8888882006
  • abo8888882006
  • 2013年10月07日 10:55
  • 54812

Git branching: master vs. origin/master vs. remotes/origin/master

Git branching: master vs. origin/master vs. remotes/origin/master up vote67down...
  • a1232345
  • a1232345
  • 2015年07月15日 13:04
  • 1022

git push origin与git push -u origin master的区别

$ git push origin 上面命令表示,将当前分支推送到origin主机的对应分支。  如果当前分支只有一个追踪分支,那么主机名都可以省略。  $ git push 如果当...
  • qq_15037231
  • qq_15037231
  • 2017年09月07日 10:40
  • 186

Git 的origin和master分析 push/diff/head

1、origin/master : 一个叫 origin 的远程库的 master 分支 2、HEAD指向当前工作的branch,master不一定指向当前工作的branch 3、git  p...
  • angle_birds
  • angle_birds
  • 2014年04月03日 10:34
  • 15694

$ git push origin test:master // 提交本地test分支 作为 远程的master分支

$ git push origin test:master         // 提交本地test分支 作为 远程的master分支
  • huaweitman
  • huaweitman
  • 2015年09月17日 09:28
  • 3987

解决本地项目上传到github时$git push -u origin master error failed to push some refs...等错误

使用命令: 1、touch README.md 2、git init 3、git add . 4、git commit -m "test" 5、git remote add origin master...
  • qq_21773607
  • qq_21773607
  • 2015年08月28日 14:31
  • 3871

git rebase的原理之多人合作分支管理

在上篇的Git rebase -i 交互变基,体验艺术般的命令文章中,我有两点为忽略了,现在补充说明下 1、在git rebase -i 后 ,用git push -f origin local_br...
  • zwlove5280
  • zwlove5280
  • 2015年07月01日 12:48
  • 2956

Git - git push origin master 报错的解决方法

1.错误提示如下: 2 [root@linux1 php]# git push -u origin master 3 To git@github.com:kangvcar/Results-Syste...
  • kangvcar
  • kangvcar
  • 2017年05月26日 21:49
  • 1344

git push origin master报错【及】MERGE_HEAD exists报错解决办法

讲一讲我在将代码同步到 GitHub 上时遇到的几个问题。 首先,如果在 GitHub 上修改了项目(比如修改 README.md),再执行 git push origin master 的话,就会报...
  • CHEndorid
  • CHEndorid
  • 2017年03月01日 21:56
  • 645
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Git 的origin和master分析
举报原因:
原因补充:

(最多只允许输入30个字)