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修改远程仓库 ...
随机推荐
- 第11章 使用Vsftpd服务传输文件
章节简述: 本章节先通过介绍文件传输协议来帮助读者理解FTP协议的用处,安装vsftpd服务程序并逐条分析服务文件的配置参数. 完整演示vsftpd服务匿名访问模式.本地用户模式及虚拟用户模式的配置方 ...
- Unity3D占用内存太大的解决方法
原地址:http://www.cnblogs.com/88999660/archive/2013/03/15/2961663.html 最近网友通过网站搜索Unity3D在手机及其他平台下占用内存太大 ...
- unity3d camera.culling mask
原地址:http://www.cnblogs.com/88999660/archive/2013/03/14/2959439.html 官方文档对CullingMask的注释只是说了通过位移运算符,可 ...
- ruby代码重构第二课
(文章都是从我的个人主页上粘贴过来的, 大家也可以访问我的主页 www.iwangzheng.com) 在第一课里提取出了相通的代码,第二课里就把常量提取出来吧 一般把常量的定义写的对应的app/mo ...
- [BZOJ2502]清理雪道
[BZOJ2502]清理雪道 试题描述 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定 ...
- 让Linux下的打印机hp1020、hp p1008自动加载固件
前言: 前段时间,处理公司打印机服务器Linux化工作.遇到问题如下:hp1020.hp1008断电后不能继续打印.而其他打印机在连接Linux打印机的情况下,断电后也能正常打印. 鉴于此情况,我搜寻 ...
- Android 云服务器的搭建和友盟APP自动更新功能的实现
setContentView(R.layout.activity_splash); //Bmob SDK初始化--只需要这一段代码即可完成初始化 //请到Bmob官网(http://www.bmob. ...
- linux文件分割(将大的日志文件分割成小的)
linux文件分割(将大的日志文件分割成小的) linux下文件分割可以通过split命令来实现,可以指定按行数分割和安大小分割两种模式.Linux下文件合并可以通过cat命令来实现,非常简单. 在L ...
- datetime中strftime和strptime用法
from datetime import * format = "%Y-%m-%d %H:%M:%S" a=datetime.now() day=a.day b=a.replace ...
- 【云计算】开源装机自动化系统 CloudBoot OSInstall 介绍
"CloudBoot"(OSinstall) 发布了. 产品更新及特点如下: 新增虚拟化操作系统适配:支持主流操作系统:RedHat.CentOS.SUSE.Ubuntu.Wind ...