Git 的origin和master分析

本文详细解析了Git中的origin和master的概念,介绍了如何通过三个主要步骤进行Git操作:获取数据、修改代码及推送更改。同时深入探讨了本地分支(local branch)与远程分支(remote branch)之间的关系,以及如何使用命令进行分支同步。

Git 的origin和master分析  

首先要明确一点,对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 branchorigin/masterremote branchmaster 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/masterorigin/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就认为你想pushremote repository下和local branch相同名字的branch。听起来有点拗口,再解释下,push是怎么个push法,就是把本地branch指向的commit pushremote repository下的branch,比如

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

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

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

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

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

你执行的命令是标准的 Git 工作流操作: 1. **`git pull origin master`** - 从远程仓库的 `master` 分支拉取最新更改,并**自动合并**到你的本地 `master` 分支。 - 如果远程本地有冲突,Git 会尝试自动合并,但如果冲突复杂,需要你手动解决。 2. **`git push origin master`** - 将本地 `master` 分支的更改推送到远程仓库的 `master` 分支。 - 如果之前 `git pull` 成功合并了远程更改,这次推送应该会顺利完成。 --- ### 可能遇到的情况及解决方法 #### ✅ **情况 1:推送成功** - 如果 `git push` 成功,说明你的本地分支已经包含远程的所有更改,并且推送是快进式的(fast-forward)。 - **无需额外操作**,继续开发即可。 #### ⚠️ **情况 2:推送失败(仍有冲突)** 如果 `git pull` 后仍然无法推送,可能是: 1. **自动合并失败**(存在冲突): - Git 会提示冲突文件,你需要手动解决冲突: ```bash # 查看冲突文件 git status # 编辑冲突文件(Git 会标记冲突部分,如 <<<<<<<) # 解决冲突后,标记为已解决 git add <冲突文件> # 完成合并 git commit -m "fix merge conflicts" # 再次推送 git push origin master ``` 2. **远程分支被其他人更新**(在 `git pull` `git push` 之间): - 再次执行 `git pull --rebase` 并解决冲突: ```bash git pull --rebase origin master git push origin master ``` #### 🔄 **情况 3:想避免自动合并,改用变基(rebase)** 如果你希望保持提交历史的线性,可以在拉取时使用 `--rebase`: ```bash git pull --rebase origin master # 代替 git pull git push origin master ``` - 如果变基过程中出现冲突: ```bash # 解决冲突后 git rebase --continue git push origin master ``` --- ### 最佳实践建议 1. **推送前先拉取**: ```bash git pull origin master git push origin master ``` 2. **使用 `git status` 检查状态**: ```bash git status # 查看是否有未提交的更改或冲突 ``` 3. **使用分支开发**(避免直接操作 `master`): ```bash git checkout -b feature-branch # 创建新分支 git push -u origin feature-branch # 推送分支并设置上游 ``` - 通过 Pull Request (PR) 或 Merge Request (MR) 合并到 `master`。 4. **强制推送慎用**: - 如果必须强制推送(如修正历史),使用 `--force-with-lease`: ```bash git push --force-with-lease origin master ``` --- ### 总结 - **标准流程**:`git pull` → 解决冲突(如果有)→ `git push`。 - **推荐变基**:`git pull --rebase` 保持历史干净。 - **团队协作**:使用分支 + PR/MR,避免直接推送 `master`。 如果仍有问题,可以提供具体的错误信息,我会帮你进一步分析! 🚀
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值