Git 备忘清单

基础配置命令

  • 查看图形界面
    gitk --all&
    
  • 显示log信息
    git log --author=name  #显示某个作者的信息
    git log --graph --oneline --decorate --all #图形化显示
    git log --pretty=oneline  # 单行显示
    git log --name-status  #显示修改文件详情
    git shortlog # 显示按字母顺序排序的人名列表,以及他们对应的提交说明
    git shortlog -s -n  # 只显示每个开发者的 commit 数量
    git log --oneline --author="Paul Lewis" #单行显示"Paul Lewis"的所有commit
    git show 5966b66 #显示SHA=5966b66的commit信息
    git log --grep=bug #显示提到bug一词的commit
    
  • 查看隐藏目录.git
    ls -ah
    
  • Git config:
    git config --global color.ui true #彩色命令行显示
    git config format.pretty oneline #单行显示
    
  • 创建SSH key
    ssh-keygen -t rsa -C "youremail@example.com"
    cat ~/.ssh/id_rsa.pub
    
  • 如何避免每次输入密码:
    1. git config --global credential.helper cache
    2. 安装Git-Credential-Manager-for-Windows
      https://github.com/Microsoft/Git-Credential-Manager-for-Windows

Git 文件状态切换:

本地操作
  • 不想追踪某个文件:

    1. Add the name to .git\info\exclude
    2. Add the name to .gitignore
  • 将改动加到staging区 stage

    git add .   #Stage all
    git add .gitignore   #stage .gitignore
    
  • 将改动移除staging区 unstage

    git reset HEAD api.c
    
    Paste_Image.png
  • 删除工作区的改动 discard

    git checkout -- api.c #discard changes in working directory
    
    Paste_Image.png
  • 删除追踪的文件 untracked

    git rm --cached api.c 
    
    Paste_Image.png
  • 恢复误删的文件

    git checkout -- api.c
    
    Paste_Image.png

git checkout 其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。

  • 删除 untracked files
    git clean -f -n  #查看可以被删除的untracked files
    git clean -f
    

分支及远程操作

  • 推送到远程

    git remote add origin git@github.com:
    git push -u origin master
    
  • 新建分支dev

    git checkout -b dev
    
  • 推送分支

    git push origin <branch> 
    
  • 删除分支

    git checkout master
    git branch -d dev  
    
  • 删除远程分支

    git push origin --delete dev
    

版本切换

  • 退回之前的版本
    在Git中,用HEAD表示当前版本,上一个版本就是HEAD^, 上上一个版本就是HEAD^^,往上100个版本HEAD~100。
    git reset --hard HEAD^
    
Paste_Image.png
  • 恢复删除的版本
    git reflog
    git reset --hard b6e2045
    
Paste_Image.png
Paste_Image.png

合并改动Merge

  • fast forward merge
    git checkout master
    git merge dev
    
  • 禁用Fast forward
    git merge --no-ff -m "merge with no-ff" dev  
    
  • 使用merge工具处理冲突
    git mergetool
    

    mergetool需要在.gitconfig 文件中配置,参见http://www.jianshu.com/p/f6deccbc8531

Submodule

  • 添加submodule
    git submodule add ssh://myrep.git
    
  • 删除submodule
    git submodule deinit -f -- submodule_folder/
    git rm -f submodule_folder/
    

Patch

  • 从某一个commit 生成patch

    git format-patch -1 <sha> --stdout > specific_commit.patch
    
  • 从当前HEAD生成包含x个commit的patch

    git format-patch -x --stdout > patch-ddmmyy.patch
    # where -x means how many commits back from the current head and it has to be integer.
    
  • 检查patch状态

    git apply --stat fix_bug.patch
    git apply --check fix_bug.patch
    
  • 打patch

    git am --signoff < fix_bug.patch
    

其他命令

  • 暂存未完成的改动
    git stash
    git stash list # 查看list
    git stash pop #恢复stash
    
    Paste_Image.png
  • 标签

    git tag V1.0 f1e9cf9 #添加
    git tag -d V0.1  #删除
    
  • 比较差异:

    git diff    #everything unstaged diffed to the last  commit
    git diff --cached  #everything staged diffed to the last commit
    git diff HEAD  #everything unstaged and staged diffed to the last commit
    
  • rebase 命令:

    git rebase -i HEAD~3 # 交互式地将 commit 变基到我们当前所在的 commit 向前三个的 commit
    git rebase origin/master # 在 master 后直接添加一个新版本,令提交历史更简洁
    

参考:

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

推荐阅读更多精彩内容