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修改远程仓库 ...
随机推荐
- java的一段对象数据类型映射的代码
try { List<GateMetaPO> listGateInfoPO = majorGateReaderService.queryForAggregateBy( chapter); ...
- java笔记--策略模式和简单工厂模式
策略模式: --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3884781.html "谢谢-- 为什么使用:策略模式主要用于 ...
- [Effective JavaScript 笔记] 第6条:了解分号插入的局限
分号可以省略 js可以在语句结束不强制加分号.(建议还是添加,不添加分号往往会出现不易发现的BUG) function Point(x,y){ this.x=x||0; this.y=y||0; } ...
- 在link的url里新增参数
(文章都是从我的个人主页上粘贴过来的,大家也可以访问我的主页 www.iwangzheng.com) <%= link_to image_tag("/images/icons/aaa. ...
- spring+hibernate常见异常集合
spring+hibernate出错小结: (1)java.lang.NoClassDefFoundError: org/hibernate/context/CurrentSessionContext ...
- ubuntu12 apache2部署多个网站的方法
由于对apache2的配置不是很精通.吃了不少瘪. 这里总结下,希望对碰到同样问题的人带来帮助: 假设需求是有两个站点,site1和site2.其端口分别为80和8080. 1. 配置监听端口 修改 ...
- shell脚本的调试技巧
请参考文章:http://www.ibm.com/developerworks/cn/linux/l-cn-shell-debug/index.html 读后的感觉,还是用shell的选项灵活,方便. ...
- webservice 协议
Web Service使用的是 SOAP (Simple Object Access Protocol)协议soap协议只是用来封装消息用的.封装后的消息你可以通过各种已有的协 ...
- 《转》Visual Studio 2010 终极定制安装精简方法
打开VS2010安装目录下的 Setup 文件夹,找到 baseline.dat 文件和 vs_setup.pdi 文件还有一个 locdata.ini 文件,是对应的. 这些都是文本文件,用记事本就 ...
- 41.把数组排成最小的数[Sort array to smallest value]
[题目] 输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个.例如输入数组{3,32, 321},则输出这两个能排成的最小数字321323.请给出解决问题的算法,并证明该 ...