美文网首页JavaJava总社区
Git远程协作和分支

Git远程协作和分支

作者: java劝退师图图 | 来源:发表于2019-07-04 14:50 被阅读2次

一、远程基本操作

基本的配置远程仓库有两个命令:

  • git remote add origin git@github.com:ZXZxin/gitlearn.git
  • git push -u origin master

这里先演示环境搭建,也就是和github上一个仓库远程关联起来,这里遇到了一些坑,记录一下:

image

坑解决的两篇文章:

普及:

  • 可以使用git remote show origin,查看详细的远程remote信息(注意origin是一个别名,不一定要这个名字)
  • git commit am '....'只会将已经纳入版本库的文件add并提交,新增的文件不会add

二、协作

一开始masterorigin/master一样。

image

然后我们需要再调用一次git push来同步远程,这样id就会相同了。

image

解释:

git内部会自己维护origin/master这个分支,我们不能操作,但是可以执行git checkout origin/master,虽然这个命令不会报错,但是我们实际上只是切换到了提交的那个点(commit-id)的位置上,也就是和之前那个游离的状态一样。我们可以在这个commit-id位置上进行修改,但是切换的时候要先stash一下。

来看一下上面的原理和过程:

初始状态:

image

然后我们调用了增加或者修改元素,调用git addgit commit之后(这时候还没有push),就会变成下面这样: (这时候git会告诉我们masterorigin/master提前了一步)

image

然后我们调用git push,注意这个过程做了两步:

  • 将本地的内容push到远程了;
  • origin/master由上面的指向了
image

三、Git协作实战

模拟环境:

  • 有两个人协作,一个张三,一个李四,张三的仓库就是我们之前用的那个gitlearn,李四是直接从张三的远程仓库git clone下来的;
  • 然后我们再将张三的gitlearn和李四的gitlearn2都设置一下user.nameuser.email

李四先git clone下来:

image

然后将张三和李四的用户名和密码配置一下:

image

现在我们在gitlearn添加一个c.txt文件,然后git push到远程仓库,然后在gitlearn2这边输入git remote show origin来查看区别:

image

remotes/origin/HEAD -> origin/master 啥意思呢?
在clone完成之后,Git 会自动为你将此远程仓库命名为originorigin只相当于一个别名,运行git remote –v或者查看.git/config可以看到origin的含义),并下载其中所有的数据,建立一个指向它的master 分支的指针,我们用(远程仓库名)/(分支名) 这样的形式表示远程分支,所以origin/master指向的是一个remote branch(从那个branch我们clone数据到本地)
也就是origin/master是用来追踪远程分支的。

然后我们在gitlearn2里面执行git pull,将远程的最新更新拉去过来。查看最新的更新信息。

image

上图的过程:

image

下面展示会发生冲突的情况:

  • 张三先修改了a.txt的第二行,然后push到了远程;
  • 李四也修改了a.txt的第二行,然后也想push到远程,就会报错;
image

此时李四要先git pull

现在展示李四的操作:

image

但是此时还不够,我们需要调用git add来标识已经解决了冲突;

image

总结git add的三个作用:

  • 将未追踪的文件(新建的文件)加入到暂存区;
  • 将已追踪的文件(修改的文件)加入到暂存区;
  • 解决完冲突之后,调用git add标识这个文件已经解决了冲突(git merge的时候)。

此时我们还需要将解决冲突之后的代码git push到远程.

image

整个过程的流程:

image

一般在git push之前都要进行git pull操作。
git pull = git fetch + git merge

git fetch会直接将代码拉到origin/master,但是和当前本地的master不会冲突。但是git merge就会产生冲突。

下面展示分别使用git fetchgit merge来操作:

先使用git fetch,不会产生冲突:

image

接下来我们在李四这边使用git merge手动解决冲突并push

image

最后在张三也进行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 删除远程分支 查看远程分支 git branch -a 删除远程分支 git push origin --...

  • 2018-05-14

    删除远程分支: git push 远程仓库 --delete 远程分支 git push 远程仓库:远程分支 本地...

  • Git之奇淫技巧

    git - 更改本地分支名称 & 远程分支 git - 删除本地分支 & 远程分支

  • git 查看远程分支、本地分支、删除本地分支

    1查看远程分支git branch -a 2查看本地分支git分支 3创建分支git分支测试 4删除远程分支git...

  • git增加远程分支

    查看远程分支 git remote -v 增加远程分支 git remote add 设置远程分支 ...

  • Git 操作

    1. Git 删除本地分支和远程分支 git 删除本地分支:git branch -D git 删除远程分支: g...

  • git命令总结及常见错误处理(一)

    分支 查看本地分支 git branch 查看远程分支 git branch -r 查看本地和远程分支 git b...

  • git常用操作

    更换远程分支先删除远程分支:git remote rm origin再添加远程分支:git remote add ...

  • pull

    git pull <远程主机名> <远程分支名>:<本地分支名> : 将远程分支与本地分支合并。git pull ...

  • git fetch 和 git pull

    git fetch 远程库名称 远程分支名称:分支名称 git pull 远程库名称 远程分支名称 远程库 位于g...

网友评论

    本文标题:Git远程协作和分支

    本文链接:https://www.haomeiwen.com/subject/wxfrhctx.html