Git远程仓库的多人协作
目录
一.项目克隆
二.多人协作
1.创建林冲仓库
2.协作处理
3.处理冲突
三.分支推送协作
四.分支拉取协作
五.远程分支的删除
一.项目克隆
我们可以把远程项目克隆到本地形成一个本地的仓库
git clone https://github.com/txjava-teach/txjava-code.git
//链接你自己的远程仓库url
我们可以发现克隆下来的仓库和远程仓库的名字一致
进入仓库可以看到.git的配置文件和远程代码
.git中的配置可以看到目前的分支为master,远程别名是origin,关联合并的是远程分支的master
注意:我们也可以克隆远程项目自己定义仓库名字
git clone https://github.com/txjava-teach/txjava-code.git testGit2
二.多人协作
1.创建林冲仓库
克隆远程仓库命名testGit1.
指定本地仓库级别的用户名和邮箱
git config --local user.name '林冲'
git config --local user.email 'linchong@txjava.com'
2.协作处理
在testGit中通过鲁智深添加文件并且推送到远程(这里的鲁智深仓库是之前创建好的仓库)
(这里是一台电脑打开两个仓库模拟多人协作的过程)
在testGit1仓库中林冲查看远程状态发现已经过期。
此时林冲应该从远程仓库来更新拉取
fast-forward表示不需要手工处理冲突直接合并
3.处理冲突
当两个人修改同一个文件的同一行的时候就会发生冲突
我们使用鲁智深修改B.txt内容后
提交并且推送到远程
此刻林冲也修改B.txt内容
我们提交并且推送远程的时候发现出现冲突,推送失败
此刻git要求我们先拉取更新
我提示中我们发现拉取成功,但是自动合并失败。git建议我们修改冲突后提交。
我们可以修改冲突,此时和svn是一样的。我们保留林冲的
推送到远程
搞定
三.分支推送协作
创建develop分支
我们发现git push无法把develop推送到远程。
执行下面的命令,这就是把本地的分支推送到远程分支。
git push --set-upstream origin develop
我们可以看到远程分支已经推送。
同时本地也关联了远程develop分支
除此之外我们可以使用下面命令完成远程分支推送
git push -u origin 分支名
我们创建分支,并且把分支推送到远程
分支查看
四.分支拉取协作
由于鲁智深已经推送,我们使用林冲的账户来拉取,我们可以看到新建立了分支
但是我们发现有远程分支,但是没有本地的develop分支。
这时我们可以创建本地的develop分支,此刻我们也可以修改本地分支的名字
git checkout -b develop origin/develop
我们已经创建分支并且切换到develop上,而且该分支和远程分支develop关联
我们还可以使用另一种方式本地分支的追踪,但是必须要先git pul
git checkout --track origin/featurel
五.远程分支的删除
我们在鲁智深仓库删除Feature分支,删除之后远程的Feature分支关联还在。
我们也可以删除对应的远程分支
git push origin --delete feature
当我们通过另一个用户来查看本地对应的远程分支的时候可以看到远程分支的变化。
查看origin远程对应的分支
git remote prune origin