git学习 远程仓库02
使用远程仓库:
- 查看当前远程库://克隆后,至少有一个名为 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 fetch [remote-name] ;//如果是克隆了一个仓库,使用
- 推送数据到远程仓库: 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的更多相关文章
- git学习——远程仓库操作
查看当前的远程库——git remote 列出了仅仅是远程库的简单名字 可以加上-v 现实对应的克隆地址 添加远程仓库——git remote add [shortname] [url] git re ...
- Git学习 -- 远程仓库
第1步:创建SSH Key 在用户目录下的.ssh目录中,查看是否有id_rsa和id_rsa.pub两个文件,若没有则通过以下命令生成秘钥对: $ ssh-keygen -t rsa 第2步:登陆G ...
- 139.00.004 Git学习-远程仓库之Github
参考Github官方HelloWorld入门教程 "有了远程仓库,妈妈再也不用担心我的硬盘了."--Git点读机 本章开始介绍Git的杀手级功能之一(注意是之一,也就是后面还有之二 ...
- 为git创建远程仓库
首先生成ssh公钥: 将公钥添加到git: 测试秘钥是否通过: 然后就可以到web界面看到标注的地方被绿了: 但是我的没有绿,不知道为啥,难道没有女朋友的原因吗? rm -rf .ssh 重来好几遍都 ...
- Git 克隆远程仓库到本地
Git 克隆远程仓库到本地 参考 $ git clone --help https://git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%8E%B7% ...
- git 切换远程仓库,以及碰到的一个问题。
git 切换远程仓库出现如下问题: $ git checkout -b localdev origin/dev fatal: Cannot update paths and switch to bra ...
- Git从远程仓库里拉取一条本地不存在的分支方法
Git从远程仓库里拉取一条本地不存在的分支方法 从远程仓库里拉取一条本地不存在的分支时,进入到对应目录先执行git fetch然后再执行git checkout -b 本地分支名 origin/远程分 ...
- git从远程仓库中更新代码到本地仓库
git从远程仓库中更新代码到本地仓库 有时候在使用git pull的时候,会莫名才报错.查了很多资料,尝试过git的很多命令.包括git fetch命令,都会报同样的错.最后终于发现了一条捷径,由网友 ...
- [转]git修改远程仓库地址
原文链接:http://www.cnblogs.com/lazb/articles/5597878.html 问:Coding远程仓库地址变了,本地git仓库地址如何更新为最新地址 git修改远程仓库 ...
随机推荐
- 那些不是秘密的微信earning方法
微信这个新兴的移动平台着实培养了一些自媒体大号,让个人也能成为媒体中心,当然微信也成为了集富利器.他们是怎么做到的呢?让我们探究一下微信earn的方法吧,一起发散思维. ★微信公众平台推广功能公测,大 ...
- zstu.4194: 字符串匹配(kmp入门题&& 心得)
4194: 字符串匹配 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 206 Solved: 78 Description 给你两个字符串A,B,请 ...
- Systemd入门教程:命令篇
导读 传统的Linux系统启动过程主要由著名的init进程(也被称为SysV init启动系统)来处理,而基于init的启动系统被认为有效率不足的问题,systemd是Linux系统机器的另一种启动方 ...
- 十条nmap常用的扫描命令
NMap也就是Network Mapper,nmap是在网络安全渗透测试中经常会用到的强大的扫描器,功能之强大,不言而喻.下面介绍一下它的几种扫描命令.具体的还是得靠大家自己学习,因为实在太强大了. ...
- C#内部类
http://blog.csdn.net/yanghua_kobe/article/details/6685222 在<Java编程思想>中花了一章的篇幅介绍,内部类的相关特性.而在C#的 ...
- 为win7添加ubuntu的启动引导项
利用MBRFix删除ubuntu的开机引导界面,恢复成win7引导之后,为win7添加ubuntu的启动引导项: 直接利用EasyBCD添加一个Grub2的引导项即可 参考:http://mathis ...
- sublime text多文件夹查找关键字
Ctrl+shift+F 快捷键在文件夹内查找,与普通编辑器不同的地方是sublime允许添加多个文件夹进行查找 转自:http://www.douban.com/note/362268947/
- 【Hibernate】Hibernate系列5之检索策略
检索策略 5.1.类级别检索策略 5.2.set多对多.一对多检索策略 5.3.多对一.一对一检索策略 HQL作用: http://zhidao.baidu.com/link?url=dnAdJWR7 ...
- CKeditor与CKfinder的简单配置
1.关掉PHP的转义字符,不然从文本框控件中得来的内容,全部有转义字符,不能正常显示,所以在取得文本框控件所传递来的数据之时,要使用下面这样的方式: $内容=stripslashes($_POST[' ...
- MFC 密码框
使用Edit Control 在属性面板中,设置“行为”为password