• git clone命令笔记

作用:远程克隆版本库
1. 克隆版本库
git clone <版本库的网址>
git clone zoran@192.168.2.167:/data/gitdata/gittest.git
如果想用其它主机名:
git clone -o zhangsan <版本库的网址>
git clone -o zoran zoran@192.168.2.167:/data/gitdata/gittest.git
2.克隆版本库到指定路径
git clone <版本库的网址> <本地目录名>
git clone zoran@192.168.2.167:/data/gitdata/gittest.git zoran
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 zoran@192.168.2.167:/path/to/repo.git 
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 fetch命令笔记

主机的版本库有了更新(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命令笔记

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命令笔记

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 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 <主机名> <网址>
git remote add zoran zoran@192.168.2.167:/data/gitdata/gittest.git
7. 删除远程主机
git remote rm <主机名>
git remote rm origin

git clone、 remote、fetch、pull、push、remote的更多相关文章

  1. GIT(6)----fork和clone的区别,fetch与pull的区别

    参考资料: [1].Git学习笔记:fork和clone的区别,fetch与pull的区别 [2].在Github和Git上fork之简单指南

  2. 【Git】Gitlab添加SSH key可以pull不能push的问题

    背景:使用webhook 钩子进行代码的自动更新 完整过程: https://zhuanlan.zhihu.com/p/93223263 问题: 在进行git pull 时候.报错了 这是gitlab ...

  3. git fetch, merge, pull, push需要注意的地方(转)

    在git操作中,我们经常会用到fetch, merge, pull和push等命令,以下是一些我们需要注意的地方. 给大家准备了参考资料: 1. Whatʼs a Fast Forward Merge ...

  4. git fetch, merge, pull, push需要注意的地方

    在git操作中,我们经常会用到fetch, merge, pull和push等命令,以下是一些我们需要注意的地方. 给大家准备了参考资料: 1. Whatʼs a Fast Forward Merge ...

  5. push 、pop 、unshift 、shift

    push .pop : 操作数组后面 unshift .shift :操作数组前面 push.unshift : 字母多的添加 pop .shift : 字母少的删除 push.unshift : 添 ...

  6. git远程操作相关命令(remote 、push、fetch 、pull)

    git remote 为了便于管理,Git要求每个远程主机都必须指定一个主机名.为了便于管理,Git要求每个远程主机都必须指定一个主机名. git remote[查看创库名] git remote 在 ...

  7. git clone、git pull和git fetch的用法及区别

    声明:码字不易,转载请注明出处,欢迎文章下方讨论交流.Git 常用命令速查表 最近在一个学习小组里学习AI的课程,我们所有的学习资料和homework都放在gitlab上.今天一个小队友从gitlab ...

  8. git pull 、git fetch、 git clone

    git clone 代表从远程克隆过来包括所有的版本信息 git fetch是从远程获取最新的版本 git pull相当于 git fetch 然后再git merge

  9. 在linux下执行git clone、git pull 、git push等操作免密

    1. 通过ssh密钥实现 ssh-keygen -t rsa -C "你的邮箱" -f "自己定义的目录" 打开: id_rsa.pub ,将文件内容复制到 g ...

随机推荐

  1. linux命令集合(二)

    yum源的配置 yum  得配置yum源,配置阿里云的 两个 yum源  ,阿里云的yum源中,会有 mariadb的软件包   阿里云的yum仓库中,mariadb版本如下 mariadb      ...

  2. C指针的运算

    指针的运算在数组中才有意义 int *p; p++,一定是在一片连续的区域才有意义,当然越界也会带来诸多问题. void main() { ; int *p = &num;//这根本无界可言 ...

  3. learning express step(十三)

    learning express error handle code: const express = require('express'); const app = express(); app.g ...

  4. fmt

    fmt.Println("hello world") fmt.Printf("%T",a)打印a 的类型 fmt.Printf("%v",a ...

  5. codeforces1213F tarjan缩点+拓扑排序

    题意 给定两个长度为n的排列p和q,构造一个字符串s满足\(s[p_i]<=s[p_{i+1}]\)和\(s[q_i]<=s[q_{i+1}]\),且满足字符串中不同字符的个数不少于k. ...

  6. NVMe - NB的特性

    翻译一下,纯粹是为了记住这些特性: NVMe provides the following benefits: ● Ultra-low latency 非常低的延迟 ● Very high throu ...

  7. C语言学习笔记2-程序基础和变量

    本系列文章由jadeshu编写,转载请注明出处.http://blog.csdn.net/jadeshu/article/details/50751977 作者:jadeshu   邮箱: jades ...

  8. 8月清北学堂培训 Day6

    今天是杨思祺老师的讲授~ 图论 双连通分量 在无向图中,如果无论删去哪条边都不能使得 u 和 v 不联通, 则称 u 和 v 边双连通: 在无向图中,如果无论删去哪个点(非 u 和 v)都不能使得 u ...

  9. BZOJ 4734 UOJ #269 如何优雅地求和 (多项式)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=4734 (UOJ) http://uoj.ac/problem/269 题解 ...

  10. Ubuntu下Nginx的安装和卸载

    环境是Ubuntu 16.04 安装: sudo apt-get update sudo apt-get install nginx 卸载: sudo apt-get --purge remove n ...