作用:远程克隆版本库
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 ...
随机推荐
- python ini文件内容的读取
(1)新建一个项目,再次新建一个文件 test_cfg.ini (2)再次新建 get_test_cfg.py,用来读取/写入/更改 ini的文件内容 #!/usr/bin/env python # ...
- Java8-Executors-No.01
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util ...
- BZOJ 1458 / Luogu P4311 士兵占领 (上下界最小流 / 直接最大流)
做法1:上下界最小流 先来一发上下界最小流,思路比较暴力,就是把行和列看作n+mn+mn+m个点,(i,j)(i,j)(i,j)如果能占领就从第iii行向第jjj列连一条边,上界为1下界为0;然后从s ...
- Spring注解详解(转)
概述 注释配置相对于 XML 配置具有很多的优势: 它可以充分利用 Java 的反射机制获取类结构信息,这些信息可以有效减少配置的工作.如使用 JPA 注释配置 ORM 映射时,我们就不需要指定 PO ...
- Entity Framework学习过程
///安装ef nuget中文控制台指令 PM> Install-Package EntityFramework.zh-Hans <!--配置数据库连接--> <connect ...
- github 管理代码、笔记
1.先注册github.com的账号官方网站: https://github.com/ 2.登录 3.创建仓库 二. 1.安装git 2.刚才我们已经在github上面创建了一个仓库,那么我们现在就在 ...
- FileInputStream读取的两种方法:逐字节读;以字节数组读取
1:read() : 从输入流中读取数据的下一个字节,返回0到255范围内的int字节值.如果因为已经到达流末尾而没有可用的字节,则返回-1.在输入数据可用.检测到流末尾或者抛出异常前,此方法一直阻塞 ...
- 图的基本存储的基本方式一(SDUT 3116)
Problem Description 解决图论问题,首先就要思考用什么样的方式存储图.但是小鑫却怎么也弄不明白如何存图才能有利于解决问题.你能帮他解决这个问题么? Input 多组输入,到文件结尾. ...
- webpack - 优化阻塞渲染的css
随着浏览器的日新月异,网页的性能和速度越来越好,并且对于用户体验来说也越来越重要. 现在有很多优化页面的办法,比如:静态资源的合并和压缩,code splitting,DNS预读取等等. 本文介绍的是 ...
- elasticsearch head插件(5.0及以上版本)
官方参考地址:https://github.com/mobz/elasticsearch-head5.0及以上版本安装参考地址:http://www.cnblogs.com/jstarseven/p/ ...