Git远程协作和分支
一、远程基本操作
基本的配置远程仓库有两个命令:
git remote add origin git@github.com:ZXZxin/gitlearn.git
;git push -u origin master
;
这里先演示环境搭建,也就是和github
上一个仓库远程关联起来,这里遇到了一些坑,记录一下:
坑解决的两篇文章:
- https://blog.csdn.net/yemoweiliang/article/details/52980658
- https://blog.csdn.net/uotail/article/details/80211897
- https://jingyan.baidu.com/article/f3e34a12a25bc8f5ea65354a.html
普及:
- 可以使用
git remote show origin
,查看详细的远程remote信息(注意origin
是一个别名,不一定要这个名字) git commit am '....'
只会将已经纳入版本库的文件add
并提交,新增的文件不会add
。
二、协作
一开始master
和origin/master
一样。
然后我们需要再调用一次git push
来同步远程,这样id
就会相同了。
解释:
git
内部会自己维护origin/master
这个分支,我们不能操作,但是可以执行git checkout origin/master
,虽然这个命令不会报错,但是我们实际上只是切换到了提交的那个点(commit-id
)的位置上,也就是和之前那个游离的状态一样。我们可以在这个commit-id
位置上进行修改,但是切换的时候要先stash
一下。
来看一下上面的原理和过程:
初始状态:
然后我们调用了增加或者修改元素,调用git add
和git commit
之后(这时候还没有push
),就会变成下面这样: (这时候git会告诉我们master
比origin/master
提前了一步)
然后我们调用git push
,注意这个过程做了两步:
- 将本地的内容push到远程了;
- 将
origin/master
由上面的①
指向了②
;
三、Git协作实战
模拟环境:
- 有两个人协作,一个张三,一个李四,张三的仓库就是我们之前用的那个
gitlearn
,李四是直接从张三的远程仓库git clone
下来的; - 然后我们再将张三的
gitlearn
和李四的gitlearn2
都设置一下user.name
和user.email
;
李四先git clone
下来:
然后将张三和李四的用户名和密码配置一下:
现在我们在gitlearn
添加一个c.txt
文件,然后git push
到远程仓库,然后在gitlearn2
这边输入git remote show origin
来查看区别:
remotes/origin/HEAD -> origin/master
啥意思呢?
在clone完成之后,Git 会自动为你将此远程仓库命名为origin
(origin
只相当于一个别名,运行git remote –v
或者查看.git/config
可以看到origin的含义),并下载其中所有的数据,建立一个指向它的master 分支的指针,我们用(远程仓库名)/(分支名)
这样的形式表示远程分支,所以origin/master
指向的是一个remote branch
(从那个branch我们clone数据到本地)
也就是origin/master
是用来追踪远程分支的。
然后我们在gitlearn2
里面执行git pull
,将远程的最新更新拉去过来。查看最新的更新信息。
上图的过程:
下面展示会发生冲突的情况:
- 张三先修改了
a.txt
的第二行,然后push到了远程; - 李四也修改了
a.txt
的第二行,然后也想push到远程,就会报错;
此时李四要先git pull
。
现在展示李四的操作:
但是此时还不够,我们需要调用git add
来标识已经解决了冲突;
总结
git add
的三个作用:
- 将未追踪的文件(新建的文件)加入到暂存区;
- 将已追踪的文件(修改的文件)加入到暂存区;
- 解决完冲突之后,调用
git add
标识这个文件已经解决了冲突(git merge
的时候)。
此时我们还需要将解决冲突之后的代码git push
到远程.
整个过程的流程:
一般在
git push
之前都要进行git pull
操作。git pull = git fetch + git merge
。
git fetch
会直接将代码拉到origin/master
,但是和当前本地的master
不会冲突。但是git merge
就会产生冲突。
下面展示分别使用git fetch
和git merge
来操作:
先使用git fetch
,不会产生冲突:
接下来我们在李四这边使用git merge
手动解决冲突并push
:
最后在张三也进行git pull
即可。
关于远程git
分支,远程(注意不是本地分支)通常有如下几种:
- 1、
master
分支: 很稳定的分支; - 2、
test
分支: 测试分支; - 3、
develop
分支: 变化最频繁的分支;s - 4、
hotfix
分支: 紧急bug需要修复;
原文:Java架构笔记
免费Java高级资料需要自己领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G。
传送门:https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q
Git远程协作和分支的更多相关文章
- git远程上的分支到本地
先想一个自己要在本地新建的分支名称,qianjinyan git checkout -b qianjinyan origin/SELLER-2248-1018 git branch 查看分支 git ...
- Git远程和分支管理
一.远程 Git是分布式版本控制系统,最重要的优点就是远程仓库托管代码.不用自己搭建一个服务器,在github上面注册一个账户就可免费获取远程仓库. 首先需要先在github上面 ...
- Git入门——远程仓库及分支管理
关于本地版本库的操作,请见:Git入门--本地版本库操作 本篇提到的所有命令: 小结 前面提到,Git相对于传统的SVN有着很大的优势,其中之一就在于集中式系统中,版本库只能存在于中央服务器上:而在G ...
- Git远程推送和抓取分支
查看远程库信息 当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin.要查看远程库的信息,用git remote,或 ...
- git推送本地分支到远程分支
场景 有时候我们开发需要开一个分支,这样可以有效的并行开发. 开分支有两种方式: 一种是在远程开好分支,本地直接拉下来; 一种是本地开好分支,推送到远程. 远程先开好分支然后拉到本地 git chec ...
- 如何删除git远程分支
1,在开发过程中,大家在远程创建了许多分支,有些是无用的,该如何删除呢,可以参考下面的方法. 如果不再需要某个远程分支了,比如搞定了某个特性并把它合并进了远程的 master 分支(或任何其他存放 稳 ...
- git 远程分支创建与推送
git 远程分支创建与推送 原文地址:http://hi.baidu.com/lingzhixu/blog/item/4a9b830bb08a329fe850cd5b.html 本地分支的创建 本 ...
- git 本地给远程仓库创建分支 三步法
命令如下: 1:本地创建分支dev Peg@PEG-PC /D/home/myself/Symfony (master) $ git branch dev 2:下面是把本地分支提交到远程仓库 Peg@ ...
- Git 远程分支的pull与push
Git 远程分支的pull与push 远程分支信息查看 git branch -r #查看远程分支 git branch -a #查看所有分支,本地和远程 git remote show [remot ...
随机推荐
- 9. [mmc subsystem] host(第三章)——sdhci-pltfm说明
一.sdhci-pltfm说明 sdhci-pltfm并不是实际某个host的driver. sdhci-pltfm是指在sdhci core的基础上,提供了统一对sdhci_host的必要属性进行解 ...
- Linux进程管理 (篇外)内核线程简要介绍【转】
转自:https://www.cnblogs.com/arnoldlu/p/8336998.html 关键词:kthread.irq.ksoftirqd.kworker.workqueues 在使用p ...
- datagrid editor动态的改变不同行修改列的editor属性
onBeforeEdit: function (row) { let options = $(this).treegrid('options'); options.tempeditor = optio ...
- MySQL 5.5/5.6/5.7及以上版本安装包安装时如何选择安装路径
安装环境需求: 自从昨天安装了mysql 5.7,发现了一个问题,mysql5.6起,已经不支持2003系统了,如果安装了无法开启服务而且会出现在 本地计算机 无法启动 MySQL57 服务.错误 1 ...
- python批量修改文件名(以修改图片名为例)
#coding=utf-8import sys, string, os, shutil #输入目录名和前缀名,重命名后的名称结构类似prefix_0001 def RenameFiles(srcdir ...
- 【Sqlite】C#不同支持
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> ...
- 树莓派autossh反向隧道
本来我是将树莓派连接到路由器,从而在电脑端通过IP访问.远在局域网之外的队友怎么访问呢? ssh反向隧道 它的原理比较简单: 树莓派主动向某公网服务器建立ssh连接,并请求公网服务器开启一个额外的SS ...
- HTTP几种认证方式介绍
HTTP提供了一套标准的身份验证框架:服务器可以用来针对客户端的请求发送质询(challenge),客户端根据质询提供身份验证凭证.质询与应答的工作流程如下:服务器端向客户端返回401(Unautho ...
- js 加载并解析Markdown文档
网上有很多网站会通过.md文档来做页面内容(比如,阮一峰老师的es6入门blog: http://es6.ruanyifeng.com/),很好奇,这是怎么做的?(至于.md是什么,或许(https: ...
- 【未完成】【Mybatis】字段由字符+数字变量组成,但要对变量进行计算
??????????????????????