使用远程仓库:

  • 查看当前远程库://克隆后,至少有一个名为 origin 的远程库,Git 默认使用这个名字来标识你所克隆的原始仓库

    • git remote -v: 并显示所有远程库的地址;
  • 添加远程仓库: 
    • git remote add [local_origin] [url]:
    • git push -u [local_origin] master //第一次推送master分支时,加上了-u参数,把本地的master分支和远程的master分支关联起来
    • git push [local_origin] master ;
  • 查看远程分支:
    • git branch -a
  • 从远程仓库抓取数据: 
    • git fetch [remote-name]  ;//如果是克隆了一个仓库,使用git fetch origin (git fetch origin remote_branch);fetch 只是将数据拉到本地仓库,并不自动合并;
    • 如果设置了某个分支用于跟踪某个远端仓库的分支,可以使用 git pull 命令自动抓取数据下来;
  • 推送数据到远程仓库: git push [remote-name] [branch-name]:

    • 例子:把本地的 master 分支推送到origin 服务器上 git push origin master
  • 创建远程分支:

    • git push origin [name];
    • 利用本地分支[name],创建远程同名的分支;
    • 注意未创建之前本地分支[name]推送到本地切出来分支对应的远程分支;
  • 删除远程分支:
    • git push origin --delete <remote_name>
  • 获取远程分支映射
    • git checkout -b local_name  orgin/remote_name;
    • 如果出现问题,先运行 git fetch,再运行上面的命令

分支管理:

  • 当前分支:一个指向你正在工作中的本地分支的指针HEAD
  • 新建分支: git branch <branchname>
  • 切换分支:   git checkout <branchname>  //此时HEAD指向新的工作分支
    • 简化:git checkout -b <branchname>
  • 删除分支:git branch -d <branchname>
    • 不能这样删除还未合并进来的分支,使用 git branch -D <branchname>强制删除;
  • 重命名分支: git branch -m <branch_name> <new_name>
  • 显示所有分支: git branch
    • 显示所有分支同时包括各个分支最后的提交:  git branch -v
    • 查看哪些分支已被并入当前分支(直接上游):  git branch --merged / --no-merged
  • 一般分支类型:
    • master分支是主分支,因此要时刻与远程同步;

    • dev分支是开发分支,所以也需要与远程同步;

    • bug分支只用于在本地修复bug,就没必要推到远程;

    • feature分支是否推到远程,取决于实际开发情况。

合并:将目标分支合并到当前分支 git merge <targetbranch>

  • Fast-forward: 顺着单线分支合并,只是将指针右移,如下

c4合并到c2;

    • 分叉分支合并:

这次合并操作的底层实现,Git 会用两个分支的末端(C4 和 C5)以及它们的共同祖先(C2)进行一次简单的三方合并计算 ;

对三方合并后的结果重新做一个新的快照,并自动创建一个指向它的提交对象,它有两个祖先;值得一提的是 Git 可以自己裁决哪个共同祖先才是最佳合并基础;

    • 遇到冲突时的分支合并:     //这时必须手动选择内容解决冲突

      • 运行git merge <targetbranch>之后,git作了合并,但没有提交,它会停下来等你解决冲突;
      • 使用git status查看发生冲突的文件;
      • 进入文件:会显示格式:

<<<<<<< HEAD
head分支冲突部分的内容
=======
目标分支冲突部分的内容
>>>>>>> <targetbrach>

1-press "i"
2-write your merge method
3-press "esc"
4-write ":wq" then press enter

  

    • 在手动修改完毕并删除多余符号之后可以将其添加到暂存区后提交了;添加暂存时会询问是否确定修改完毕;
    • 用git log --graph命令可以看到分支合并图。
  • 非Fast-forward合并:
    • git merge --no-ff -m "merge with no-ff" dev
    • 合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。

衍合: //与分支合并(merge)不同,分支衍合(rebase)是把一个分支里提交的改变移到另一个分支里重放一遍;

  • $ git checkout experiment
    $ git rebase master

它的原理是回到两个分支最近的共同祖先,根据当前分支(也就是要进行衍合的分支 experiment)后续的历次提交对象(这里只有一个 C3),生成一系列文件补丁,然后以基底分支(也就是主干分支master)最后一个提交对象(C4)为新的出发点,逐个应用之前准备好的补丁文件,最后会生成一个新的合并提交对象(C3'),从而改写 experiment 的提交历史,使它成为 master 分支的直接下游,如图 所示:

现在回到 master 分支,进行一次快进合并:

其结果是和merge相同的,但会有个更简介的提交历史;

本地分支rebase之后可能不能进行push,这时候使用git push -f;

多人协同工作:

  • 查看添加的远程地址: git remote -v
  • 添加远程地址: git remote add [name] [url]
  • git fetch [name]
  • 操作: git push/pull [name] [origin_branch]

切出commit分支  

  • git branch -b [new_name] [hash]

git学习 远程仓库02的更多相关文章

  1. git学习——远程仓库操作

    查看当前的远程库——git remote 列出了仅仅是远程库的简单名字 可以加上-v 现实对应的克隆地址 添加远程仓库——git remote add [shortname] [url] git re ...

  2. Git学习 -- 远程仓库

    第1步:创建SSH Key 在用户目录下的.ssh目录中,查看是否有id_rsa和id_rsa.pub两个文件,若没有则通过以下命令生成秘钥对: $ ssh-keygen -t rsa 第2步:登陆G ...

  3. 139.00.004 Git学习-远程仓库之Github

    参考Github官方HelloWorld入门教程 "有了远程仓库,妈妈再也不用担心我的硬盘了."--Git点读机 本章开始介绍Git的杀手级功能之一(注意是之一,也就是后面还有之二 ...

  4. 为git创建远程仓库

    首先生成ssh公钥: 将公钥添加到git: 测试秘钥是否通过: 然后就可以到web界面看到标注的地方被绿了: 但是我的没有绿,不知道为啥,难道没有女朋友的原因吗? rm -rf .ssh 重来好几遍都 ...

  5. Git 克隆远程仓库到本地

    Git 克隆远程仓库到本地 参考 $ git clone --help https://git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%8E%B7% ...

  6. git 切换远程仓库,以及碰到的一个问题。

    git 切换远程仓库出现如下问题: $ git checkout -b localdev origin/dev fatal: Cannot update paths and switch to bra ...

  7. Git从远程仓库里拉取一条本地不存在的分支方法

    Git从远程仓库里拉取一条本地不存在的分支方法 从远程仓库里拉取一条本地不存在的分支时,进入到对应目录先执行git fetch然后再执行git checkout -b 本地分支名 origin/远程分 ...

  8. git从远程仓库中更新代码到本地仓库

    git从远程仓库中更新代码到本地仓库 有时候在使用git pull的时候,会莫名才报错.查了很多资料,尝试过git的很多命令.包括git fetch命令,都会报同样的错.最后终于发现了一条捷径,由网友 ...

  9. [转]git修改远程仓库地址

    原文链接:http://www.cnblogs.com/lazb/articles/5597878.html 问:Coding远程仓库地址变了,本地git仓库地址如何更新为最新地址 git修改远程仓库 ...

随机推荐

  1. CocoStudio基础教程(4)骨骼动画的动态换肤

    1.概述 游戏中人物的状态会发生改变,而这种改变通常要通过局部的变化来表现出来.比如获得一件装备后人物形象的改变,或者战斗中武器.防具的损坏等.这些变化的实现就要通过动态换肤来实现. 2.运行到程序 ...

  2. uchome 2.0 存在持久XSS漏洞

    发布时间:2010-09-03 影响版本:uchome 2.0 漏洞描述:看源码分析的,出错位置较敏感,而且基本没有利用限制,个人主页自定义风格时,可@import外部css文件 测试方法: 本站提供 ...

  3. SGU 179 Brackets light(生成字典序的下一个序列)

    题目链接:http://acm.sgu.ru/problem.php?contest=0&problem=179 解题报告:输入一个合法的括号串,求出这个括号串的字典序的下一个串.(认为'(' ...

  4. zookeeper 用法和日常运维

    本文以ZooKeeper3.4.3版本的官方指南为基础:http://zookeeper.apache.org/doc/r3.4.3/zookeeperAdmin.html,补充一些作者运维实践中的要 ...

  5. Python win7下 django-admin.py startproject mysite命令没有创建mysite?

    解决方案 解决:这个命令在XP下正常(我没试过),我用的win7,无法创建.这属于django的一个bug. 方法是:修改注册表中 HKEY_CLASSES_ROOT/Applications/pyt ...

  6. Linux Apache和Nginx的比较

    1.nginx相对于apache的优点: 轻量级,同样起web 服务,比apache占用更少的内存及资源 抗并发,nginx 处理请求是异步非阻塞的,而apache 则是阻塞型的,在高并发下nginx ...

  7. Linux 怎么重命名多个文件

    下面是重命名命令的基本语法. rename [-v -n -f] <pcre> <files> <pcre> 是Perl兼容正则表达式,它表示的是要重命名的文件和该 ...

  8. .Net Attribute特性

    1.什么是Atrribute 首先,我们肯定Attribute是一个类,下面是msdn文档对它的描述: 公共语言运行时允许你添加类似关键字的描述声明,叫做attributes, 它对程序中的元素进行标 ...

  9. windows下如何对mysql进行整裤备份

    通常情况下备份一个数据库,直接单裤备份即可,更完善一点的会要求做到定时单裤备份.然而很多时候又由于裤实例是在太多,这样会导致备份非常耗时,因而有时候需要对整个数据库应用进行备份.那么在windows下 ...

  10. 【python】捕获所有异常

    如下所示,在不知道异常名的情况下可以捕获所有异常 try: a=b b=c except Exception,ex: print Exception,":",ex