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修改远程仓库 ...
随机推荐
- matlab figure 论文级别绘图
1.将figure调整为最大: figure;set(gcf,'outerposition',get(0,'screensize')); 2.获得figure中的大小 [x,y] = ginput 3 ...
- Linux简单的常用命令——纯手打(慢慢积累)
==============linux下快捷键==================ctrl+insert 复制shift +insert 粘贴 输入文件名的前三个字母,按tab键自动补全文件名 在vi ...
- Android--UI之EditText
前言 上一篇博客介绍了Android的TextView控件,这篇博客来说一下EditText控件.EditText为一个文本控件,提供了文本输入的功能,而且继承自TextView,可以理解为可以输入的 ...
- NGUI 学习笔记实战之二——商城数据绑定(Ndata)
上次笔记实现了游戏商城的UI界面,没有实现动态数据绑定,所以是远远不够的.今天采用NData来做一个商城. 如果你之前没看过,可以参考上一篇博客 NGUI 学习笔记实战——制作商城UI界面 ht ...
- PHP快速抓取快递信息
<?php header("Content-type:text/html;charset=utf-8"); /** * Express.class.php 快递查询类 * @ ...
- fsck检查和修复文件系统
重视:fsck不能乱用.先要把文件系统umount掉,然后检查.最好启动到单用户模式下fsck. 常见的5种损坏类型 1 未被引用的inode 2 难以置信的超大链接数 3 没有记录在磁盘块映射表中的 ...
- php数组转换js数组操作及json_encode应用
对于php,个人感觉能够熟练操作数组和字符串,基本上已经是入门了,php本身有很多操作数组和字符串的函数,今天在做一个功能时,需要用Js动态的创建门店信息,这些信息是要从后台添加的,想来想去,通过ph ...
- 特殊表达式的意义[c++ special expressions]
[本文链接] http://www.cnblogs.com/hellogiser/p/special-expressions.html x&(x-1)表达式的意义: 统计二进制中1的个数. ...
- 搭建CAS单点登录服务器
最近公司的一个项目需要用到单点登录的功能,之前对单点登录了解得不多.于是网上找了下单点登录的解决方案,发现CAS是个不错的解决方案.于是搭个环境测试了一下.这里记录下测试的详细步骤. 官网:http: ...
- CHM文档打开空白的解决
网上打包的CHM格式的文档,有时候打开无论点击目录哪一章节都会出现一片空白或者显示已取消到该网页的导航 这个情况的原因就是CHM文件在Windows的HTFS文件系统中会默认被阻止显示,解决方法就是在 ...