Git 常用命令

撤销

  1. 查看log git log找到要撤销的commit id
  2. 撤销后并还原文件git reset --hard commit id 这里的commit id是要撤销的id的前一个,就是要撤销到哪一个commit
  3. 撤销后可以再次提交 git reset commit id 这里的id同 2
  4. 撤销任意一个commit git revert commit id

撤销远程的

  1. 如果是最近的一个commit,先本地撤销后,然后强制推送git push origin master --force就可以了
  2. 如果是任意一个commit,这个除了新建分支使用cherry-pick来解决之外,最简单的方式是git rebase。rebase命令可是使用对commit进行编排(删除,修改),具体的可以参考这篇文章

忽略某个文件

  1. 临时的忽略一个文件,比如在vue项目中生成的index.html文件每次都会有变动,但是并不是每次都想提交,如果不想再提交的时候看到这个文件,我们可以使用update-index命令
    a. git update-index --assume-unchanged <file>
    b. git update-index --no-assume-unchanged <file>

避免pull出现Merge branch 'master' of xxx, 有3种方法

  1. git pull --rebase 这个会先撤销本地的所有commit, pull最新的代码,然后在新的代码上应用所有的本地commit,如果出现conflict,你可以手动merge,然后执行git rebase --continue
  2. 在.git/config中配置每次pull都rebase
[branch "master"]
  rebase = true

cli配置 git config branch.master.rebase true

  1. 全局配置
[branch]
  autosetuprebase = always

cli配置git config --global branch.autosetuprebase always

创建本地中心仓库/裸仓库bare

git init --bare project.git

一般用来做远端中心仓库或者本地演示git命令

tag

  1. 添加 git tag -a 0.1.3 <SHA值> -m “Release version 0.1.3
  2. 删除 git tag -d 0.1.3
  3. 推送到仓库 git push origin --tags
  4. 删除仓库 git push origin :refs/tags/0.1.3
  5. 搜索标签 git tag -l 1.*.* *星号匹配对于的位置

清除多余的文件

git clean -n         # 查看将要被删除的文件,不做真正的删除
git clean -f         # 执行删除
git clean -f -d      # 删除目录
git clean -f -X      # 删除ignored文件

merge

git merge --squash branch # 合并只生成一个commit

删除分支

git push -d origin branch1                               # 删除远程分支
git branch --delete --remotes origin branch1             # 删除远程分支的本地跟踪
git branch -dr origin branch1                            # 上面的缩写
git branch -D branch1                                    # 删除本地分支

输出history

具体format参数参考这里

git log --format="%H %B"  => 872acd6b45102a36b06ac9c7e8b4977b84025205 修改
git log --oneline => 0751fe6 fixbug
git log --pretty=format:"%h - %an, %ar : %s"
=> d309e46 - auther, 3 days ago : fixbug

获取当前分支

git symbolic-ref --short -q HEAD

合并多个commit

git rebase -i commitid #需要合并的commitid 起始位置

在rebase界面把需要合并的commit改成s或者square,但是需要保留一个起始位置

编辑第一个commit

git rebase -i --root

实际问题

  1. 在配合其他IC(比如jenkins)使用webhook时,有时为了测试需要触发push event。
1. git commit --amend --no-edit  # 修改最后一次提交,但是不做修改
2. git push -f                   # 强制推送就能在不新增commit的情况下出发push
  1. git在win下是默认不区分大小的,如果你的代码需要在linux环境下编译。最好修改这个设置,让git区分大小写。
git config core.ignorecase false

遇到的问题

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

推荐阅读更多精彩内容

  • 陈梅军阅读 150评论 0 0
  • 感冒咳嗽依旧,或许大姨妈来的缘故吧,这次提前了一个星期!突然讨厌现在的自己,现在的生活,可也没法去改变,唯一的方...
    乐铛麻麻阅读 156评论 0 0
  • 我和孩子、老师那些事 一转眼飞飞已经在明天幼稚集团第九幼儿园的大家庭中生活了一年多了,当年还是个小豆丁的他慢慢变的...
    nksnr阅读 267评论 0 0