拾遗:Git 常用操作回顾

温故而知新,可以为师矣。

Git 布局

  • 工作区---->暂存区---->本地仓库---->远程仓库

Create Repository

  • git init PATH
  • git add PATH
  • git commit -m CONTENTS

Revoke

  • HEAD 表示当近一次 commit 版本,HEAD^ 或 HEAD~1 表示上一次提交,HEAD^^ HEAD~2(波浪线) 表示上上次提交...依次类推;也可以用 [email protected]{N}  或 哈希值等形式直接定位(根据 reflog 显示的历史 HEAD 记录)
  • git status
  • git diff [--staged/--cached] [COMMIT] [-- PATH]:默认是比较工作区与 HEAD 之间的差异,添加 --staged 或 --cached 则是默认比较暂存区与 HEAD 之间的差异,两种情况均可以指定要比较的 commit hash,可以用 -- filename 的形式指定要比较的具体文件
  • git diff [BRANCH_0] [BRANCH_1] —— 比较个分支最新提交之间的差异
  • git reset [--hard] COMMIT [PATH] —— 根据 git log 或 git reflog 查到的 SHA1 值,在版本之间进行全局文件或指定文件的状态回退,reset 的作用是将仓库中的文件恢复至暂存区(--soft,默认值)或工作区(--hard)
  • git reflog —— 暂时记录最近的每一条 git 操作记录内容及其 HASH,即 HEAD 的变动记录,该记录不会永久保存
  • git checkout [COMMIT] -- PATH —— 撤销工作区中单个文件的修改,恢复到上一个最新状态(可能是暂存区或本地仓库中的状态,以时间戳为准),必须添加 ‘--‘,否则会被理解为切换分支,可以指定从哪个次提交状态恢复
  • git reset 与 git checkout 的区别:reset 只能恢复已经 commit 到版本库中的状态,checkout 可以恢复到暂存区中的状态是,reset 会同时将 git log 中对应的记录删除
  • git rm [PATH] —— 同时删暂存区及工作区中的文件,添加 --cached 选项仅删除暂存区中的文件
  • git mv [PATH] [PATH] —— 重命名,同时作用于暂存区及工作区
  • git  revert COMMIT —— 从远程仓库撤销已 push 的提交
  • git commit --amend -m "CONTENTS" —— 修改最近一次提交的备注内容
  • git rebase BRANCH —— 重新选定本分支的起点,同时不丢失历史提交记录

Remote Repository

  • git remote add TAG [email protected]:USERNAME/PROJECTNAME.git —— 其中 TAG 指为远程仓库打的标签,以此标识每个仓库
  • git push [-u] [REPOSITORY_TAG] [BRANCH] —— 将本地仓库文件推送至远程,初次推送时添加 -u 选项将本地仓库分支与远程仓库分支关联
  • git fetch —— 下载远程仓库代码但不合并,人工检查无误后 git merge
  • git pull —— 下载同时合并
  • git pull --rebase —— 拉取远程代码的同时,更新本地仓库起点

Branch Management

  • git branch BRANCH_NAME [BASE_BRANCH] —— 基于 BASE_BRANCH 创建新分支,默认基于当前所在分支
  • git checkout BRANCH_NAME —— 切换分支
  • git checkout -b BRANCH_NAME —— 创建一个分支同时切换过去
  • git merge [--no-ff] BRANCH_NAME —— 合并目录分支到当前分支,git 默认是 fast forward 合并模式,此模式下合并后,被合并的分支上原先的操作计录都将消失,添加 --no-ff 选项表示不使用 fast forward 模式,分支的相关记录得以保留
  • git branch -d BRANCH_NAME —— 删除已经被合并过的分支
  • git branch -D BRANCH_NAME —— 删除没有被合并过的分支
  • git stash —— 将当前工作区中已被 git add 但未提交的文件隔离保存(不是放到暂存区),并处于不可见状态,即 git status 不会提示更改未提交
  • git stash list —— 显示被隔离保存起来的状态列表
  • git stash apply [STASH] —— 恢复隔离区的指定 stash
  • git stash pop [STASH] —— 同 apply,但会同时从 stash 列表删除该条目
  • git stash drop [STASH] —— 手动删除某个 stash 条目,默认都是针对最新的 stash
  • git stash clear —— 清除所有stash 条目
  • git remote [-v] —— 显示远程仓库信息,-v 显示详细信息,如仓库地址等
  • git branch BRANCH_NAME UPSTEAM —— 建立分支的同时关联到远程分支
  • git branch -r —— 显示远程分支
  • git branch -a —— 同时显示远程与本地分支
  • git branch --set-upstream-to=origin/develop develop —— 建立与连程分支的关联,若不指定分支名称,则关联当前所在分支到远程(如:origin/master 等)

Tags(助记符,方便人类记忆,毕竟 hash 值不好分辩)

  • git tag TAGNAME [-a -m CONTENTS] [COMMIT_HASH] —— 默认是给最近一次提交打标签,可以指定目标 commit 的 hash 值,还可以添加标签说明(-a -m "...")
  • git tag —— 显示所有标签列表
  • git show TAGNAME —— 可显示与指定标签关联的 commit 相关信息
  • git tag -d TAGNAME —— 删除本地标签
  • git push REMOTE_REPOSITORY TAGNAME —— 将标签关信息推送至远程仓库
  • git push REMOTE_REPOSITORY --tags —— 推送所有标签信息推送至远程仓库
  • git push REMOTE_REPOSITORY :refs/tags/TAGNAME —— 用于删除远程标签,先要 git tag -d 删除本地标签,然后执行此操作删除远程标签

Alias(设置 git 命令别名)

  • 示例:git config --global alias.lg "log --color --graph --pretty=format:‘%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset‘ --abbrev-commit"

删除与重命名远程分支:

  • git push --delete origin dev  //删除无程分支
  • git push --delete origin tag <TagName>  //删除远程标签
  • git remote prune origin //清除本地显示的,但远程仓库中已不存在的僵死分支
  • git fetch -p  //效果同上
  • git branch -m dev develop  //将本地分支 dev 分支重命名为 develop
时间: 2024-10-18 17:36:43

拾遗:Git 常用操作回顾的相关文章

git 常用操作集锦

创建仓库 新建普通仓库: [email protected]:~/workspace/git$ git init Reinitialized existing Git repository in /home/jxdong/workspace/git/.git/ 新建 bare 仓库: [email protected]:~/workspace/git.git$ git init --bare Initialized empty Git repository in /home/jxdong/wor

git报错:&#39;fatal:remote origin already exists&#39;怎么处理?附上git常用操作以及说明。

git添加远程库的时候有可能出现如下的错误, 怎么解决? 只要两步: 1.先删除 $ git remote rm origin 2.再次执行添加就可以了. ----------------------------------------------git常用操作------------------------------------------------ 说明,以下整理来自廖雪峰大神的<git教程>. 各位童鞋要下载git但是网速不给力的,可以从这里下载:https://pan.baidu.

Git工程开发实践(三)——Git常用操作

Git工程开发实践(三)--Git常用操作 一.Git仓库操作 1.Git仓库创建 git init在当前目录中初始化Git仓库git init [project-name]创建一个新目录并初始化仓库初始化git仓库会默认创建一个mater分支,创建名为.git的子目录,内含初始化Git仓库中所有的骨干文件,此时仓库中的文件还没有被跟踪.通过git add命令来实现对指定文件的跟踪,然后执行git commit提交. git add . git commit -m 'initial projec

一图学完GIT常用操作

git是目前最广泛使用的版本控制软件.虽然git功能齐全,完全掌握需要花费一番功夫,然而,对于普通的开发者而言,常用的操作及其有限,而不常用的操作,即使学习了,也会很快忘记.因此,我个人的观点是我们仅仅需要掌握自己常用的操作即可.下图是我对git常用操作的一个总结,现公布出来,以飨大家.另推荐一本git学习极好的书籍<git pro>:https://vdisk.weibo.com/s/ADfpX8eK88Km. 原文地址:https://www.cnblogs.com/doctor-li/p

git常用操作笔记

这是我看了廖雪峰的git教程,写的笔记,仅作为一个学习的记录 一.大多数我们面临的是已经有一个进行中的项目了,我们只需克隆下来就可以了 1.安装git,安装完后,可输入git,回车,查看是否已安装 2.配置全局用户名     $git config --global user.name "Your Name" 配置邮箱地址        $git config --global user.email "[email protected]" 3.在一个空的文件夹里,右

git常用操作

git init 初始化 git status 查看git commit 文件的状态 git add <file>文件加入下一个commit git rm <fiile> 文件从下一个commit stage中删除,同时删除物理文件 git reset HEAD <file> 文件从下一个commit stage中删除,但不删除物理文件 git commit -m "test commit" 发射一个commit git commit --amend

git - 常用操作汇总

远程仓库相关命令 检出仓库:$ [email protected]:yaoxiabing/saltstack.git查看远程仓库:$ git remote -v添加远程仓库:$ git remote add [name] [url]删除远程仓库:$ git remote rm [name]修改远程仓库:$ git remote set-url --push [name] [newUrl]拉取远程仓库:$ git pull [remoteName] [localBranchName]推送远程仓库:

git学习笔记03-本地git常用操作及原理-文件增删改

1.查看git状态 git status  这个可以告诉我们对git做了哪些操,比如增删改 2.既然我们修改了东西,有的时候想看看修改了什么,毕竟我们的记忆力并不如电脑 git diff 文件名 (默认和暂存区比较.啥事暂存区后面说) 3.修改了之后我提交了,我想看看提交的日志git log -- pretty = oneline  (后面这是格式化用的,可以不写) 4.突然想起来我提交的这个有错误怎么办,我想恢复到之前的版本 git reset --hard HEAD^ ( HEAD^ 是之前

git 常用操作

from:  http://rogerdudler.github.io/git-guide/index.zh.html git - 简明指南 助你入门 git 的简明指南,木有高深内容 ;) 作者:罗杰·杜德勒 感谢:@tfnico, @fhd 和 Namics其他语言 english, deutsch, español, français, indonesian, italiano, nederlands, polski, português, русский, türkçe, ??????,