git 常用命令

常用命令

add        Add file contents to the index
bisect     Find by binary search the change that introduced a bug
branch     List, create, or delete branches
checkout   Checkout a branch or paths to the working tree
clone      Clone a repository into a new directory
commit     Record changes to the repository
diff       Show changes between commits, commit and working tree, etc
fetch      Download objects and refs from another repository
grep       Print lines matching a pattern
init       Create an empty Git repository or reinitialize an existing one
log        Show commit logs
merge      Join two or more development histories together
mv         Move or rename a file, a directory, or a symlink
pull       Fetch from and merge with another repository or a local branch
push       Update remote refs along with associated objects
rebase     Forward-port local commits to the updated upstream head
reset      Reset current HEAD to the specified state
rm         Remove files from the working tree and from the index
show       Show various types of objects
status     Show the working tree status
tag        Create, list, delete or verify a tag object signed with GPG

常用命令行

master    默认开发主干分支
origin    默认远程版本库
Head      默认开发分支
Head^     Head的福提交
  • 版本库
git clone <url>                     #克隆远端版本库
git init                            #初始化本地版本库
  • 分支与标签
git branch                          #查看所有本地分支
git branch -a                       #查看所有分支
git branch -r                       #查看所有远端分支
git branch <new branch>             #创建新分支
git branch <branch2> <branch1>      #以branch1分支为基础创建branch2分支
git branch -d <branch>              #删除本地分支
git branch -m <oldbranch> <newbranch>#分支重命名
git checkout <branch/tag>           #切换到指定分支或者标签
git tag                             #查看所有本地标签
git tag <new tag>                   #基于最新提交创建标签
git tag -d <tag>                    #删除标签

  • 修改和提交代码
git status                          #查看当前状态
git diff                            #查看变更内容
git add .                           #把所有变动的文件添加到暂存区
git add <file>                      #把指定的文件添加到暂存区
git mv <oldname> <newname>          #文件更名
git rm <file>                       #删除文件
git rm --cached <file>              #停止跟踪文件但不删除
git commit -m '<commit message>'    #提交文件
git commit --amend                  #对上一次的提交进行修改。既可以对上次提交的内容进行修改,也可以修改提交说明
  • 合并与衍合
git merge <branch>                  #合并指定分支的代码到当前分支
git rebase <branch>                 #衍合指定分支到当前分支
  • 远程操作
git remote -v                       #查看远程版本库信息
git remote show <remote>            #查看指定远程版本库信息
git remote add <remote> <url>       #添加远程版本库
git fetch <remote>                  #从远程库获取代码
git pull <remote> <branch>          #下载代码及快速合并
git push <remote> <branch>          #上传代码及快速合并
git push <remote> :<branch/tag>     #删除远程分支或标签
git push --tags                     #上传所有标签
  • 撤销
git reset --hard HEAD               #撤销工作目录中所有未提交文件的修改
git checkout HEAD <file>            #撤销指定的未提交文件的修改
git revert <commit>                 #撤销指定的提交
  • 其他
git log                             #查看提交历史
git log -p <file>                   #查看指定文件的提交历史
git blame <file>                    #以列表方式查看指定文件的提交历史
git stash push                      #将文件给push到一个临时空间中
git stash pop                       #将文件从临时空间pop下来

汇总常用的一些操作

git checkout -b dev #创建新的本地分支并切换到新分支,等价于
git branch dev
git checkout dev

#提交代码
git add 
git commit 

git status #查看当前状态

git remote show #查看远程库
git remote show origin #查看远程库origin里边的资源

git merge origin/dev #将远程dev分支与当前分支进行合并

git push origin master #将本地项目给提交到服务器中


git代码发布流程

假如开发分支为dev 线上分支为online

  1. 创建功能分支 dev
git checkout -b dev
  1. 功能迭代
(dev) git commit
  1. 合并最新线上分支代码到开发分支
(dev) git checkout online
(online) git pull
(online) git checkout dev
(dev) git merge online
#解决冲突
(dev) git commit

  1. 功能迭代
(dev) git commit
  1. 测试通过,合并代码到线上的online分支
#先执行一遍第三步,也就是合并最新线上分支代码到开发分支,以防冲突
(dev) git checkout online 
(online) git merge dev --squash 
(online) git commit #
推送到远端,正常结束 
(online) git push origin

如果这一步被拒绝,是因为online有更新的代码提交了,为了防止online上出现冲突,需要重新执行这一步

参考文档

Git 常用命令速查表(图文+表格) https://www.cnblogs.com/kenshinobiy/p/4543976.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容