作用:远程克隆版本库
1. 克隆版本库
git clone <版本库的网址>
如果想用其它主机名:
git clone -o zhangsan <版本库的网址>
2.克隆版本库到指定路径
git clone <版本库的网址> <本地目录名>
2.克隆支持的协议类型
支持:HTTP(s)、SSH、Git、本地文件协议等,如:
git clone http[s]://example.com/path/to/repo.git/
git clone ssh://example.com/path/to/repo.git/ or
git clone git://example.com/path/to/repo.git/
git clone /opt/git/project.git git clone file:///opt/git/project.git
git clone ftp[s]://example.com/path/to/repo.git/
git clone rsync://example.com/path/to/repo.git/
主机的版本库有了更新(Git术语叫做commit),需要将这些更新取回本地,这时就要用到git fetch命令,只跟新不合并。
1. 全部更新回本地
git fetch <远程主机名>
git fetch origin
git fetch .
2. 更新指定分支
git fetch <远程主机名> <分支名>
git fetch origin dev
git fetch origin master
tips:取回的更新,在本地主机上要用"远程主机名/分支名"的形式读取。比如origin主机的master,就要用origin/master读取。
3. 查看远程分支
git branch -r
4. 查看远程所有分支
git branch -a
5.更新并创建新分支
git checkout -b newBrach origin/master
tips:在origin/master的基础上,创建一个新分支
6. 本地分支上合并远程分支
git merge origin/master # 或者 git rebase origin/master
tips:表示在当前分支上,合并origin/master。
git pull命令的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并
1.取回分支更新,与本地指定分支合并
git pull <远程主机名> <远程分支名>:<本地分支名>
git pull origin next:master //origin主机的next分支,与本地的master分支合并
如果远程分支是与当前分支合并,则冒号后面的部分可以省略,如:
git pull origin dev
实际取回origin/dev分支,再与当前分支合并。实质上,这等同于先做git fetch,再做git merge。
git fetch origin git merge origin/dev
2.手动指定(追踪)本地分支与远程分支的关联
git branch --set-upstream-to=origin/next //当前分支关联远程origin/next分支
如果当前分支与远程分支存在关联关系,git pull可以省略远程分支名,如:
git pull origin
如果当前分支只有一个追踪分支,连远程主机名都可以省略,如:
git pull
如果远程主机删除了某个分支,默认情况下,git pull 不会在拉取远程分支的时候,删除对应的本地分支。这是为了防止,由于其他人操作了远程主机,导致git pull不知不觉删除了本地分支。但是,你可以改变这个行为,加上参数 -p 就会在本地删除远程已经删除的分支。
git pull -p
# 等同于下面的命令
git fetch --prune origin
git fetch -p
3. rebase模式合并
git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
git pull --rebase origin dev:dev
git push命令用于将本地分支的更新,推送到远程主机。
1. 本地分支的更新推到远程主机
git push <远程主机名> <本地分支名>:<远程分支名>
git push origin dev:dev
如果省略远程分支名,则表示将本地分支推送与之存在"链接(追踪)关系"的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。
git push origin dev//本地dev分支推送到origin主机的dev分支;如果后者不存在,则会被新建.
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
git push origin :dev
# 等同于
git push origin --delete master //删除origin主机的master分支
2.本地分支对应多个远程主机,可推送到指定主机,并设置默认主机,使用git push就可以不加任何参数了
git push -u <远程主机名> <本地分支名称>
git push -u origin master //本地的master分支推送到origin主机,同时指定origin为默认主机
3.不管是否存在远程分支,都可以将本地分支推到远程
git push --all origin //本地分支都推送到origin主机
4.远程主机比推送版本新,如需强制推送
如果远程主机的版本比本地版本更新,推送时Git会报错,要求先在本地做git pull合并差异,然后再推送到远程主机。这时,如果你一定要推送,可以使用--force选项。-使用场景,确定代码是你提交,存在错误,不需要处理差异,直接覆盖,可以这么做,慎用。
git push --force origin
5.git push不推送标签(tag),如需推送标签
git push origin --tags //使用--tags选项
git remote
Git要求每个远程主机都必须指定一个主机名。git remote命令就用于管理主机名。
1.列出所有远程主机
git remote
2. 查看远程主机的网址
git remote -v
3. 克隆版本库自定义名称
tips:克隆版本库的时候,所使用的远程主机自动被Git命名为origin。如果想用其他的主机名,需要用git clone命令的-o选项指定。
git remote 输出 jQuery
4. 查看主机详细信息
git remote show <主机名>
git remote show origin
5. 远程主机改名
git remote rename <原主机名> <新主机名>
git remote rename origin zoran
6.添加远程主机
git remote add <主机名> <网址>
7. 删除远程主机
git remote rm <主机名>
git remote rm origin
- GIT(6)----fork和clone的区别,fetch与pull的区别
参考资料: [1].Git学习笔记:fork和clone的区别,fetch与pull的区别 [2].在Github和Git上fork之简单指南
- 【Git】Gitlab添加SSH key可以pull不能push的问题
背景:使用webhook 钩子进行代码的自动更新 完整过程: https://zhuanlan.zhihu.com/p/93223263 问题: 在进行git pull 时候.报错了 这是gitlab ...
- git fetch, merge, pull, push需要注意的地方(转)
在git操作中,我们经常会用到fetch, merge, pull和push等命令,以下是一些我们需要注意的地方. 给大家准备了参考资料: 1. Whatʼs a Fast Forward Merge ...
- git fetch, merge, pull, push需要注意的地方
在git操作中,我们经常会用到fetch, merge, pull和push等命令,以下是一些我们需要注意的地方. 给大家准备了参考资料: 1. Whatʼs a Fast Forward Merge ...
- push 、pop 、unshift 、shift
push .pop : 操作数组后面 unshift .shift :操作数组前面 push.unshift : 字母多的添加 pop .shift : 字母少的删除 push.unshift : 添 ...
- git远程操作相关命令(remote 、push、fetch 、pull)
git remote 为了便于管理,Git要求每个远程主机都必须指定一个主机名.为了便于管理,Git要求每个远程主机都必须指定一个主机名. git remote[查看创库名] git remote 在 ...
- git clone、git pull和git fetch的用法及区别
声明:码字不易,转载请注明出处,欢迎文章下方讨论交流.Git 常用命令速查表 最近在一个学习小组里学习AI的课程,我们所有的学习资料和homework都放在gitlab上.今天一个小队友从gitlab ...
- git pull 、git fetch、 git clone
git clone 代表从远程克隆过来包括所有的版本信息 git fetch是从远程获取最新的版本 git pull相当于 git fetch 然后再git merge
- 在linux下执行git clone、git pull 、git push等操作免密
1. 通过ssh密钥实现 ssh-keygen -t rsa -C "你的邮箱" -f "自己定义的目录" 打开: id_rsa.pub ,将文件内容复制到 g ...
随机推荐
- 二、vue基础--计算属性和监听器
1.一些操作需要计算后才能得到的用计算属性,需要放在computed属性中代码如下: <div id='app'> <div> <label>宽:</labe ...
- BZOJ 3864 Hero meet devil (状压DP)
最近写状压写的有点多,什么LIS,LCSLIS,LCSLIS,LCS全都用状压写了-这道题就是一道状压LCSLCSLCS 题意 给出一个长度为n(n<=15)n(n<=15)n(n< ...
- UVA323 Jury Compromise
思路:背包类DP 提交:3次 错因:没有注意得分的上下界导致 RE 显示 WA 题解: 我们很容易的想到把两种分数做一个差,来尽量背到 \(0\) . 那最大化总分呢?这时我们可以用两种分数的和作为物 ...
- Mongodb账户管理
Mongodb账户管理 介绍 Mongodb是一个schema free的非sql类分布式数据库,可以利用它做很多很灵活的存储和操作,最近了解了下它的账户机制,通过设置auth启动方式可以对所有登 ...
- word文档如何选择全部图片粘贴
很多时候我们用一些管理系统的时候,发布新闻.公告等文字类信息时,希望能很快的将word里面的内容直接粘贴到富文本编辑器里面,然后发布出来.减少排版复杂的工作量. 下面是借用百度doc 来快速实现这个w ...
- 畅通工程续(HDU 1874)(简单最短路)
某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多.这让行人很困扰. 现在 ...
- java试题复盘——11月25日
上: 11.下列表述错误的是?(D) A.int是基本类型,直接存数值,Integer是对象,用一个引用指向这个对象. B.在子类构造方法中使用super()显示调用父类的构造方法,super()必须 ...
- 微信小程序开发常见坑
前段时间稍微涉猎了微信小程序开发,踩了一些坑,在此总结出来,希望能为小伙伴们提供一点帮助. 页面跳转 对于页面跳转,可能习惯性想到wx.navigateTo,但是在跳转到目标页面是一个tab时,此接口 ...
- 感知机和BP神经网络
一.感知机 1.感知机的概念 感知机是用于二分类的线性分类模型,其输入是实例的特征向量,输出是实例的类别,类别取+1和-1二个值,+1代表正类,-1代表负类.感知机对应于输入空间(特征空间)中将实例分 ...
- dd 命令
dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512:c=1:k=1024:w=2 参数注释: if=文件名:输入文件名 ...