git学习(6)多人协作

当我们从远程仓库克隆的时候,git会自动的把本地的master和远程的master对应起来,并且远程仓库的默认名称是origin

查看远程库的信息

$ git remote
origin $ git remote -v
origin git@github.com:keithmorning/gitstudy.git (fetch)
origin git@github.com:keithmorning/gitstudy.git (push)

推送分支的时候,添加上分支的名称,就能把分支推送到远程库对应的远程分支上

$ git push orignin master
$ git push origin dev

如果远程没有该分支会自动添加,但是如果dev存在,且你的git目录是从origin clone来的,那么你需要自己建立分支,语法 $ git checkout -b dev origin/dev,如果是自己建立dev分支提交到远程dev分支的是还需要自己建立Track,语法$ git branch --set-upstream=origin/dev

一步一步来看,首先先看不小心自己建立dev 需要添加Track

$ git clone git@github.com:KeithMorning/gitStudy.git
Cloning into 'gitStudy'...
remote: Counting objects: 64, done.
remote: Compressing objects: 100% (38/38), done.
remote: Total 64 (delta 19), reused 59 (delta 14)
Receiving objects: 100% (64/64), 5.44 KiB | 0 bytes/s, done.
Resolving deltas: 100% (19/19), done.
Checking connectivity... done.
//克隆成功
$ ls
gitStudy
$ cd gitStudy
$ ls
currentwork.txt newDev.txt readme.txt
/*建立新分支*/
$ git checkout -b dev
Switched to a new branch 'dev' /*vim新建文件goodstudy.h*/
$ ls
currentwork.txt goodstudy.h newDev.txt readme.txt /*当前dev分支提交修改*/
$ git add goodstudy.h
$ git commit -m "add new code on dev"
[dev 114cffc] add new code on dev
1 file changed, 1 insertion(+)
create mode 100644 goodstudy.h

好了现在我们push一下试试

$ git push origin dev
To git@github.com:KeithMorning/gitStudy.git
! [rejected] dev -> dev (non-fast-forward)
error: failed to push some refs to 'git@github.com:KeithMorning/gitStudy.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

这里新建的dev和远程库的dev内容都是不一样的哦,跟我们新建一个devotherName是一样的,所以先pull一下吧

$ git pull
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details git pull <remote> <branch> If you wish to set tracking information for this branch you can do so with: git branch --set-upstream-to=origin/<branch> dev

git提醒我们没有当前的分支建立连接,因此可以通过最后的提示来修改当前分支和远程分支的联系,

$ git branch --set-upstream-to=origin/dev
Branch dev set up to track remote branch dev from origin.

我们在pull一下试试

$ git pull
Merge branch 'dev' of github.com:KeithMorning/gitStudy into dev
。。。

提醒我们将本地dev分支和远程dev分支合并,输入合并的原因,或者不输入取消合并,注意这个时候进入的是vim模式,点击i进入编辑模式,输入原因后,点击esc,然后输入:wq

$ git pull
Merge made by the 'recursive' strategy.
code.m | 1 +
readme.txt | 1 +
2 files changed, 2 insertions(+)
create mode 100644 code.m

好了现在可以push

$ git push origin dev
Counting objects: 7, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (5/5), 552 bytes | 0 bytes/s, done.
Total 5 (delta 2), reused 0 (delta 0)
To git@github.com:KeithMorning/gitStudy.git
032fc97..3611fbb dev -> dev

如果一开始使用的是$ git checkout -b dev orign/dev会自动添加本地分支和远程分支分关系,需要做的就是完成本地分支修改后,提交后push就可以了

在上一步中我们使用pull的时候进行了一次分支合并,如果不幸出现合并的时候冲突怎么办呢

如A同学修改了readme.txt并已经做了提交和push,当我们也修改了readme.txt进行push的时候会发生冲突如

$ git push origin dev
To git@github.com:KeithMorning/gitStudy.git
! [rejected] dev -> dev (fetch first)
error: failed to push some refs to 'git@github.com:KeithMorning/gitStudy.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first integrate the remote changes
hint: (e.g., 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

我们需要先pull一下看看那

$ git pull
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (1/1), done.
remote: Total 3 (delta 2), reused 3 (delta 2)
Unpacking objects: 100% (3/3), done.
From github.com:KeithMorning/gitStudy
23e511f..98eae17 dev -> origin/dev
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.

好了现在打开冲突的文件readme.txt,可以看到冲突的地方进行修改后重新提交就可以了

最后付上外国友人制作的表单

git学习(6)多人协作的更多相关文章

  1. git学习:多人协作,标签管理

    多人协作: 查看远程库的信息, git remote 推送分支到远程库 git push origin master/dev 注意:master是主分支,时刻需要与远程同步 dev是开发分支,也需要与 ...

  2. git 学习笔记 --多人协作

    当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin. 要查看远程库的信息,用git remote: $ git r ...

  3. git 分支管理——多人协作

    git 分支管理--多人协作 一般一个项目有一个master主分支,还有一个develop开发分支.主要是在develop分支上协作开发,然后merge合并到master主分支上. 当从远程仓库克隆时 ...

  4. Git版本控制之多人协作

         上篇文章我们主要简单的介绍了有关git的一些基本常识和一些简单的命令.但那终究是皮毛,我们使用git最主要的目的还是管理我们的项目,多人协作.本篇文章主要涉及以下两个大模块: 分支的概念及原 ...

  5. Git教程之多人协作

    当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin.要查看远程库的信息,用git remote:

  6. Git详细教程---多人协作开发

    Git可以完成两件事情: 1. 版本控制 2.多人协作开发 如今的项目,规模越来越大,功能越来越多,需要有一个团队进行开发. 如果有多个开发人员共同开发一个项目,如何进行协作的呢. Git提供了一个非 ...

  7. GIT简单使用——多人协作篇

    多人协作的工作模式通常是这样:1.首先,可以试图用git push origin <branch-name>推送自己的修改:2.如果推送失败,则因为远程分支比你的本地更新,需要先用git ...

  8. Git_学习_04_ 多人协作开发的过程

    多人协作的工作模式通常是这样: 1.首先,可以试图用 git push origin branch-name 推送自己的修改: 2.如果推送失败,则因为远程分支比你的本地更新,需要先用 git pul ...

  9. Git 分支管理 多人协作 远程仓库 补充

    当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了, 并且,远程仓库的默认名称是origin. 如果是本地仓库关联远程仓库 --- 要查看远程库的信息,用 ...

  10. 记录git多人协作开发常用的流程,供新手参考

    声明:博主写的博客都是经过自己总结或者亲测成功的实例,绝不乱转载.读者可放心看,有不足之处请私信我,或者给我发邮件:pangchao620@163.com. 写作目的: 记录一下我看完廖学锋老师的gi ...

随机推荐

  1. jquery的liveQuery插件

    一.livequery插件简介 jQuery的事件绑定功能使得jQuery代码与HTML代码能够完全分离,这样代码的层次关系更加清晰,维护起来也更加简单.然而对于动态加载到页面的HTML元素,每次都需 ...

  2. Ubuntu/Debian下编译PC版的ffmpeg

    1.安装git: 在命令行下执行 sudo apt-get install git-core 2.下载最新版本的ffmpeg: git clone git://source.ffmpeg.org/ff ...

  3. boost 库的安装

    一.windows下 环境:win7 64位 方法1:使用.exe类型的boost进行安装,也就是编译过得,这种方法最简单.下载后直接执行.exe就行了. http://sourceforge.net ...

  4. Bootstrap学习笔记(8)--响应式导航栏

    说明: 1. 响应式导航栏,就是右上角的三道杠,点一下下方出现隐藏的导航栏.如果屏幕够大就显示所有的导航选项,如果屏幕小比如手机,就显示部分,剩下的放到三道杠里隐藏. 2. 外面套一个大的div,其实 ...

  5. 针对16v554(ttyS0-15)的ttyAT0的login配置

    1 ## /etc/inittab# console::sysinit:/etc/init.d/rcSconsole::respawn:/sbin/getty -L 115200 ttyAT0 vt1 ...

  6. 嵌入式linux性能详解_转

    最近简单看了下<嵌入式Linux性能详解>一书,对系统内存分布测试.程序运行.动态库等都很很好的解析. 作者史子旺,loughsky@sina.com. 有时间希望仔细通读,并验证.

  7. 扩展KMP - HDU 4333 Revolving Digits

    Revolving Digits Problem's Link Mean: 给你一个字符串,你可以将该字符串的任意长度后缀截取下来然后接到最前面,让你统计所有新串中有多少种字典序小于.等于.大于原串. ...

  8. Differential Geometry之第八章常Gauss曲率曲面

    第八章.常Gauss曲率曲面 1.常正Gauss曲率曲面 2.常负Gauss曲率曲面与Sine-Gordon方程 3.Hilbert定理 4.Backlund变换 4.1.线汇与焦曲面 4.2.Bac ...

  9. 第二百六十二节,Tornado框架-cookie

    Tornado框架-cookie Cookie 是网站用来在客户端保存识别用户的一种小文件.一般来用库可以保存用户登 录信息.购物数据信息等一系列微小信息. self.set_cookie()方法,创 ...

  10. shell命令技巧——文本去重并保持原有顺序

    简单来说,这个技巧相应的是例如以下一种场景 假设有文本例如以下 cccc aaaa bbbb dddd bbbb cccc aaaa 如今须要对它进行去重处理.这个非常easy,sort -u就能够搞 ...