git命令

一. 克隆,提交,拉取代码

1. 克隆,提交代码

  • git clone:远端仓库地址
  • git remote add upstream: 上游远端仓库地址(fork代码的原地址)。添加上游远端仓库
  • git add -A
  • git commit -m '描述'
  • git push

2. 从上游远端仓库拉取冲突代码,解决冲突

  • git pull upstream master -r:把冲突部分拉下来,使用rebase合并代码,不会产生合并信息,不使用rebase确实回产生的。pull细节:把工作区的修改暂存起来,把远端代码和上一次提交合并,然后把暂存的修改再合并到分支上
  • git add -A
  • git rebase --continue:重新提交代码文件,不会产生额外的commit。如果合并的分支中存在多个commit,需要重复处理多次冲突。 只有处理冲突时候才能用这个命令。
  • git push -f:强制提交代码

3. 修补最近一次的提交

  • git commit —amend(-a):修补最近一次push

4. 拉取代码

  • git pull 等价于 git fetch & git merge:这时从远端拉取代码,回产生一个合并日志,产生分叉
  • git pull --rebase (-r):使用 git rebase 合并代码

二. 删除远端误提交代码文件

  • git rm —cached test.txt:不删除本地文件的情况下,删除远端文件
  • git rm -f test.txt:删除远端文件的同时删除本地文件
  • git rm -r test:删除远端文件夹的同时删除本地文件夹
  • 做完上述删除动作,直接commit就好,不用add

三. 撤销修改

  • git reset --hard version:修改本地仓库版本
  • git reset HEAD 文件:把提交到缓存区的代码,回退到本地工作区
  • git checkout --文件:撤销本地工作区的修改

四. 标签管理

  • git tag:列出所有标签
  • git show v1.0:查看标签信息
  • git tag v1.0 commit:给分支打标签。在后面添加commit信息,可以把标签打到以前的commit上
  • git tag -a 标签名 -m '标签描述' 1094adb:给标签写上描述
  • git tag -d v1.0:删除标签
  • git push origin v1.0:提交标签到远程仓库

五. 分支管理

  • git branch:列出所有分支
  • git branch <branch>:创建分支
  • git branch -av:显示所有远程、本地分支,并显示最后提交的commit信息
  • git branch -d :小写时分支上的commit必须已经全部合并到其他分支;大写为强制删除
  • git checkout :切换分支
  • git checkout -b :创建并切换分支
  • git merge -m '合并信息' :合并分支
  • git merge --abort:放弃这次merge(同时也放弃pull)

六. diff

  • git diff:比较修改后的文件和修改前的文件的区别
  • git diff commit:比较工作区和指定提交之间的比较

七. log

  • git log:查看日志
  • git log --graph:查看提交历史图表
  • git log --oneline:把提交信息整合到一行显示
  • git log --stat:显示某次commit中添加行、删除行的总数

八. rebase

  • git rebase --abort:放弃本次变基操作
  • git rebase :基于某个提交(或分支)重新提交你的代码。在另一个分支提交修改代码,然后切换回master分支,执行命令,把另一个分支合并到master分支。并不会产生额外提交信息。

九. 初始化

  • git init:初始化
  • .gitignore:忽略提交文件
  • README.md:代码描述文件

十. 暂存修改

  • git stash:保存当前工作区到暂存区
  • git stash list:列出当前保存的修改
  • git stash pop:弹出保存的修改

十一. 一些心得体验

  • rebase,实际上这个命令没这么难,我解说下。
  • 当使用git rebase <branch>合并分支的时候。会把你当前的commit给去除,临时保存起来,然后把要合并的分支,从开始分叉的地方,全部搬到master分支上,然后把临时保存的commit放在头部,这样就变成了一条线。如果接下来再使用rebase,他会续借原来的分支commit,而不是放在头部
  • 如果使用merge的话,会存在一个分叉,然后再合并到master上,多产生一个commit信息
  • master:commit1=>commit2
  • dev:dev1=>dev2
  • 这两个分支使用rebase合并
  • commit1=>dev1=>dev2=>commit2,如果继续使用rebase,
  • commit1=>dev1=>dev2(dev分支上的commit全都会加入到这后面)=>commit2(master分支的commit全部会加入到这后面)
  •  如果使用merge的话
  •  commit1=>dev1=>dev2=>commit2=>merge dev(新产生一个commit信息,合并分支的)
  •  dev3(从dev2产生分叉)

---恢复内容结束---

# git命令

一. 克隆,提交,拉取代码

1. 克隆,提交代码

  • git clone:远端仓库地址
  • git remote add upstream: 上游远端仓库地址(fork代码的原地址)。添加上游远端仓库
  • git add -A
  • git commit -m '描述'
  • git push

2. 从上游远端仓库拉取冲突代码,解决冲突

  • git pull upstream master -r:把冲突部分拉下来,使用rebase合并代码,不会产生合并信息,不使用rebase确实回产生的。pull细节:把工作区的修改暂存起来,把远端代码和上一次提交合并,然后把暂存的修改再合并到分支上
  • git add -A
  • git rebase --continue:重新提交代码文件,不会产生额外的commit。如果合并的分支中存在多个commit,需要重复处理多次冲突。 只有处理冲突时候才能用这个命令。
  • git push -f:强制提交代码

3. 修补最近一次的提交

  • git commit —amend(-a):修补最近一次push

4. 拉取代码

  • git pull 等价于 git fetch & git merge:这时从远端拉取代码,回产生一个合并日志,产生分叉
  • git pull --rebase (-r):使用 git rebase 合并代码

二. 删除远端误提交代码文件

  • git rm —cached test.txt:不删除本地文件的情况下,删除远端文件
  • git rm -f test.txt:删除远端文件的同时删除本地文件
  • git rm -r test:删除远端文件夹的同时删除本地文件夹
  • 做完上述删除动作,直接commit就好,不用add

三. 撤销修改

  • git reset --hard version:修改本地仓库版本
  • git reset HEAD 文件:把提交到缓存区的代码,回退到本地工作区
  • git checkout --文件:撤销本地工作区的修改

四. 标签管理

  • git tag:列出所有标签
  • git show v1.0:查看标签信息
  • git tag v1.0 commit:给分支打标签。在后面添加commit信息,可以把标签打到以前的commit上
  • git tag -a 标签名 -m '标签描述' 1094adb:给标签写上描述
  • git tag -d v1.0:删除标签
  • git push origin v1.0:提交标签到远程仓库

五. 分支管理

  • git branch:列出所有分支
  • git branch <branch>:创建分支
  • git branch -av:显示所有远程、本地分支,并显示最后提交的commit信息
  • git branch -d :小写时分支上的commit必须已经全部合并到其他分支;大写为强制删除
  • git checkout :切换分支
  • git checkout -b :创建并切换分支
  • git merge -m '合并信息' :合并分支
  • git merge --abort:放弃这次merge(同时也放弃pull)

六. diff

  • git diff:比较修改后的文件和修改前的文件的区别
  • git diff commit:比较工作区和指定提交之间的比较

七. log

  • git log:查看日志
  • git log --graph:查看提交历史图表
  • git log --oneline:把提交信息整合到一行显示
  • git log --stat:显示某次commit中添加行、删除行的总数

八. rebase

  • git rebase --abort:放弃本次变基操作
  • git rebase :基于某个提交(或分支)重新提交你的代码。在另一个分支提交修改代码,然后切换回master分支,执行命令,把另一个分支合并到master分支。并不会产生额外提交信息。

九. 初始化

  • git init:初始化
  • .gitignore:忽略提交文件
  • README.md:代码描述文件

十. 暂存修改

  • git stash:保存当前工作区到暂存区
  • git stash list:列出当前保存的修改
  • git stash pop:弹出保存的修改

十一. 一些心得体验

  • rebase,实际上这个命令没这么难,我解说下。
  • 当使用git rebase <branch>合并分支的时候。会把你当前的commit给去除,临时保存起来,然后把要合并的分支,从开始分叉的地方,全部搬到master分支上,然后把临时保存的commit放在头部,这样就变成了一条线。如果接下来再使用rebase,他会续借原来的分支commit,而不是放在头部
  • 如果使用merge的话,会存在一个分叉,然后再合并到master上,多产生一个commit信息
  • master:commit1=>commit2
  • dev:dev1=>dev2
  • 这两个分支使用rebase合并
  • commit1=>dev1=>dev2=>commit2,如果继续使用rebase,
  • commit1=>dev1=>dev2(dev分支上的commit全都会加入到这后面)=>commit2(master分支的commit全部会加入到这后面)
  •  如果使用merge的话
  •  commit1=>dev1=>dev2=>commit2=>merge dev(新产生一个commit信息,合并分支的)
  •  dev3(从dev2产生分叉)

git一些实践命令,关于reabse和merge的区别在最后做了一个比较的更多相关文章

  1. Git的常用命令记录

    Git的常用命令记录 1.与远程仓库建立连接,即关联一个远程库 git remote add origin git@server-name:path/repo-name.git; 2.查看当前分支  ...

  2. 『现学现忘』Git后悔药 — 34、git commit --amend 命令

    目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...

  3. Git初级实践教程(图文)

    关于Git Git的由来 Linux 的创始人 Linus Torvalds 在 2005 年开发了 Git 的原型程序.当时,由于在 Linux 内核开发中使用的既有版本管理系统的开发方许可证发生了 ...

  4. Git 最佳实践:分支管理

    5月份,为统一团队git分支管理规范,刚开始准备自己写,在网上搜了下,发现不少不错的git分支管理实践.最后我为团队选择了这个git分支管理实践 A successful Git branching ...

  5. Git 少用 Pull 多用 Fetch 和 Merge

    本文有点长而且有点乱,但就像Mark Twain Blaise Pascal的笑话里说的那样:我没有时间让它更短些.在Git的邮件列表里有很多关于本文的讨论,我会尽量把其中相关的观点列在下面. 我最常 ...

  6. GIT 版本控制常用命令学习汇总

    GIT 版本控制常用命令汇总 git version 查看当前git版本信息 git help 获取全部命令帮助信息 git help <command> 获取指定命令帮助信息 git c ...

  7. git的一些命令行

    以下代码均在命令行中执行:在目标文件夹目录下: 1.初始化一个Git仓库,使用git init命令. 2.添加文件到Git仓库,分两步: 第一步,使用命令git add <file>,注意 ...

  8. git的常用命令

    简介  上篇讲解git的博客,在centos6.5中安装完成了github客户端,接下来我们来熟悉git的操作命令 1.查看自己机器中安装的git版本 [root@jacky conf]# git - ...

  9. Git基本常用命令

    Git基本常用命令如下: mkdir: XX (创建一个空目录 XX指目录名) pwd: 显示当前目录的路径. git init 把当前的目录变成可以管理的git仓库,生成隐藏.git文件. git ...

随机推荐

  1. L - The Shortest Path Gym - 101498L (dfs式spfa判断负环)

    题目链接:https://cn.vjudge.net/contest/283066#problem/L 题目大意:T组测试样例,n个点,m条边,每一条边的信息是起点,终点,边权.问你是不是存在负环,如 ...

  2. Java的IO流——(七)

    目录结构:

  3. 【CTF MISC】隐写术wireshark找出图片-“强网杯”网络安全挑战赛writeup

    这场CTF中有一道题是分析pcap包的.. 13.大黑阔: 从给的pcap包里把图片提取出来,是一张中国地图. 题目提示是黑阔在聊天,从数据里可以找出几段话. 思路:主要考察wireshark的过滤规 ...

  4. 什么是 maven的uber-jar

    在maven的一些文档中我们会发现 "uber-jar"这个术语,许多人看到后感到困惑.其实在很多编程语言中会把super叫做uber (因为suber可能是关键字), 这是上世纪 ...

  5. python实战===教你用微信每天给女朋友说晚安

    但凡一件事,稍微有些重复.我就考虑怎么样用程序来实现它. 这里给各位程序员朋友分享如何每天给朋友定时微信发送”晚安“,故事,新闻,等等··· ···最好运行在服务器上,这样后台挂起来更方便. 准备: ...

  6. WebSphere的jython编码的一个坑

    was5.1版本,用"name=" in line这类判断字符串包含的方式时,系统会提示报错 TypeError: string member test needs char le ...

  7. 巧用CASE WHEN 验证用户登录信息

    最近逛博客园的时候偶然看到一个很巧妙的SQL,巧妙利用CASE WHEN 实现一个简单的 SQL 同时验证用户帐号是否存在.密码是否正确.晓菜鸟之前的做法都是根据用户名和密码一起验证,如果验证失败直接 ...

  8. 001_TCP/IP TIME_WAIT状态原理及监控实战

    一.原理 <1>TIME_WAIT状态原理---------------------------- 通信双方建立TCP连接后,主动关闭连接的一方就会进入TIME_WAIT状态. 客户端主动 ...

  9. centos6.5环境自动化运维之puppet实现nginx反向代理功能及puppet安装配置详解

    puppet是一种Linux.Unix.windows平台的集中配置管理系统,使用自有的puppet描述语言,可管理配置文件.用户.cron任务.软件包.系统服务等.puppet把这些系统实体称之为资 ...

  10. Go语言规格说明书 之 Go语句(Go statements)

    go version go1.11 windows/amd64 本文为阅读Go语言中文官网的规则说明书(https://golang.google.cn/ref/spec)而做的笔记,介绍Go语言的 ...