Git 常用命令及常见问题记录

git config

$ git config -l  //查看所有的配置信息,依次是系统级别、用户级别、仓库级别
$ git config --global -l // 查看全局

$ git config <key>  //检查 Git 的某一项配置
$ git config user.name // 查看用户名
$ git config user.email // 查看用户邮箱

$ git config --global --edit  //编辑配置文件

// 设置全局
$ git config --global user.name "Author Name"
$ git config --global user.email "Author Email"
// 设置当前项目库配置
$ git config user.name "Author Name"
$ git config user.email "Author Email"

//删除配置信息
$ git config --global --unset user.name  
$ git config --global --unset user.email 

//无需每次都输入密码
//输入密码后执行下面代码就可以了
$ git config --global credential.helper store

//修改密码
//如果账号密码有变动 用这个命令
$ git config --system --unset credential.helper

//重新输入账号密码 应该就能解决了
//如果用了第一个命令 还不能解决问题那么 用这个命令:
$ git config --global http.emptyAuth true

git clone

$ git clone <版本库的网址> //与远程主机的版本库同名
$ git clone <版本库的网址> <本地目录名>  //指定不同的目录名
$ git clone -o <其他的主机名> <版本库的网址>  //指定用其他主机名
//克隆版本库远程主机自动被Git命名为`origin`。如果想用其他的主机名,`git clone`命令的`-o`选项指定

git remote

为了便于管理,Git要求每个远程主机都必须指定一个主机名。

`git remote` : 列出所有远程主机
`git remote -v` : 查看远程主机的网址
`git remote show <主机名>` : 查看该主机的详细信息
`git remote add <主机名> <网址>` : 添加远程主机
`git remote rm <主机名>` : 删除远程主机
`git remote rename <原主机名> <新主机名>` : 远程主机的改名

git branch

git branch : 查看本地分支

git branch -a : 查看远程分支

git branch branchName : 创建分支

git checkout mybranch : 切换分支

git checkout -b mybranch : 创建并切换分支

git branch -d branchName : 删除本地分支

git push origin :branch_a : 删除远程分支branch_a
git push origin --delete branch_a : 删除远程分支branch_a

更改本地和远程分支的名称:

git branch -m old_branch new_branch # 修改本地分支名称
git push origin :old_branch # 删除远程旧的分支 
git push --set-upstream origin new_branch # Push the new branch, set local branch to track the new remote

git fetch

git fetch <远程主机名> : 将某个远程主机的更新,全部取回本地

git fetch <远程主机名> <分支名> : 只取回特定分支的更新

$ git fetch origin master #取回origin主机的master分支

git pull

git pull <远程主机名> <远程分支名>:<本地分支名>
取回远程主机某个分支的更新,再与本地的指定分支合并

$ git pull origin master:dev #取回origin主机的master分支,与本地的dev分支合并
$ git pull origin master #取回origin/master分支,再与当前分支合并。实质上等同于先git fetch,再git merge
$ git fetch origin
$ git merge origin/master

git status

git status : 检查当前文件状态输出十分详细

git status -s : 简短输出

git diff

查看具体修改了什么地方
git diff : 尚未缓存的改动

git diff --stat : 显示摘要而非整个diff:

git diff --cached : 查看已缓存的改动

git diff HEAD : 查看已缓存的与未缓存的所有改动

git diff --staged

git commit

每次准备提交前,先用 git status 看下,是不是都已暂存起来了, 然后再运行提交命令 git commit

git commit -a -m 'added new benchmarks' 跳过暂存

git commit --amend --no-edit push前 追加提交 不修改提交说明

git rm

git rm log/\*.log : 删除 log/ 目录下扩展名为 .log 的所有文件

git rm \*~ : 删除以 ~ 结尾的所有文件。

git rm -f <file> : 删除之前修改过并且已经放到暂存区域的文件,加 -f

git rm --cached <file> : 如果把文件从暂存区域移除,但仍然希望保留在当前工作目录中,换句话说,仅是从跟踪清单中删除,加 --cached

git tag

git tag : 列出标签

git tag tagName : 添加标签

git tag -d tagName : 删除标签

git push origin tagName : 提交标签

git push origin :refs/tags/v0.1 : 删除远程标签 v0.1

git mv

用于移动或重命名一个文件、目录、软连接

git mv file_from file_to

git merge

--no-ff:不使用fast-forward方式合并,保留分支的commit历史
--squash:使用squash方式合并,把多次分支commit历史压缩为一次

git merge --ff : fast-forward方式就是当条件允许的时候,git直接把HEAD指针指向合并分支的头,完成合并。属于“快进方式”,不过这种情况如果删除分支,则会丢失分支信息。因为在这个过程中没有创建commit

git merge --squash : 是用来把一些不必要commit进行压缩,比如说,你的feature在开发的时候写的commit很乱,那么我们合并的时候不希望把这些历史commit带过来,于是使用--squash进行合并,此时文件已经同合并后一样了,但不移动HEAD,不提交。需要进行一次额外的commit来“总结”一下,然后完成最终的合并

# dev分支的修改合并到master主分支步骤
$ git checkout master    #切换到master主分支
$ git pull origin master #更新代码
$ git merge dev --no-ff  #dev合并到主分支
$ git push origin master #提交到主分支
$ git branch -d dev      #删除本地dev分支
$ git push origin --delete dev  #git branch -a 查看远程分支,删除远程dev分支

git push

git push <远程主机名> <本地分支名>:<远程分支名> : 将本地分支的更新,推送到远程主机

git reset

git reset HEAD : 取消之前 git add 添加,但不希望包含在下一提交快照中的缓存
git reset --mixed : 头指针恢复,add的缓存也会丢失掉,工作空间的代码不变
git reset --soft : 头指针恢复,add的缓存不变,工作空间的代码不变。如果还要提交,直接commit即可
git reset --hard : 头指针恢复,aad的缓存消失,本地的源码也会变为上一个版本的内容,彻底回退到某个版本

git stash

会把所有未提交的修改(包括暂存的和非暂存的)都保存起来,用于后续恢复当前工作目录

$ git stash save "save message"   //执行存储时,添加备注
$ git stash list  //查看现有stash
$ git stash pop stash@{num} //只能恢复一次
$ git stash apply stash@{num} //可恢复多次
$ git stash drop stash@{num} //删除某个保存
$ git stash clear //删除所有保存

常见问题解决

修改本地和远程分支的名称

#将本地分支进行改名
$ git branch -m old_branch new_branch

# 删除远程分支
$ git push origin :old_branch
# or
$ git push --delete origin old_branch 

#将改名后的分支push到远程
$ git push origin new_branch

撤销add

$ git reset HEAD . #撤销所有add文件 
$ git reset HEAD -filename #撤销单个add文件 

撤销commit

$ git log #可查看提交记录

$ git reset --soft  版本号 
$ git reset --soft HEAD^  #回到上一个版本
#不删除工作区改动的代码,撤销commit,不撤销git add .

$ git reset --mixed 版本号 
$ git reset --mixed HEAD^  #回到上一个版本
# 不删除工作区改动的代码,撤销commit,撤销git add .

$ git reset --hard 版本号 
$ git reset --hard HEAD^  #回到上一个版本
# 删除工作区的代码,撤销commit,撤销git add . 回到上一次commit的状态

撤销commit 未push

$ git log #找到想要撤销的id 
$ git reset --soft <commit版本号> 
# 撤销,但不对代码修改撤销,可通过git commit 重新提交对本地代码的修改

撤销commit 已经push

$ git log
$ git reset --hard <commit版本号> 
#完成撤销,同时将代码恢复到前一commit_id 对应的版本 
$ git push <远程主机名> <本地分支名>:<远程分支名> --force
#要加上force 不然会提示
#error: failed to push some refs to '地址'
#hint: Updates were rejected because the tip of your current branch is behind

Git也允许手动建立追踪关系

#指定dev分支追踪origin/master分支
$ git branch --set-upstream dev origin/master 
#当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名
$ git pull origin

忽略某个被追踪的文件的修改

#如果文件已经被跟踪,再放到.gitinore可能会失效,用以下命令来忽略
$ git update-index --assume-unchanged your_file_path 
#撤销用:
$ git update-index --no-assume-unchanged your_file_path 

把指定的dist文件提交到gh-pages分支上

$ git subtree push --prefix=dist origin gh-pages 

git log 如何退出操作

Q

Git Push 避免用户名和密码方法

http://www.cnblogs.com/ballwql/p/3462104.html

#全局配置
$ git config --global user.name "username" 
$ git config --global user.email "email"
$ git config --global credential.helper store
#输入这个命令后,只需要输入一次用户名密码

设置只有自己需要忽略的文件

修改.git/info/exclude文件

gitlab新增分支后,本地 git branch -r 看不到新增的分支

$ git fetch --all

gitlab上删除分支后,本地 git branch -r 还能看到

$ git branch -a  #查看所有本地分支和远程分支,发现很多在远程仓库已经删除的分支在本地依然可以看到
$ git remote show origin  #可以查看remote地址,远程分支,还有本地分支与之相对应关系等信息
$ git remote prune --dry-run origin #查看当前有哪些是该消失还存在的分支
$ git remote prune origin  #删除本地那些远程仓库不存在的分支
$ git fetch --prune origin  #如果没有结果输出说明已经删除完成了

git只合并某一个分支的某个commit

$ git log  #在对应分支查看要合并的commitid
$ git checkout branch-current  #切换到当前分支
$ git cherry-pick commit-id

git pull 报错 refusing to merge unrelated histories

$ git pull origin master --allow-unrelated-histories

git pre -commit hook failed (add --no-verify to bypass)的问题

husky > pre-commit (node v8.9.4)
  ↓ Stashing changes... [skipped]
    → No partially staged files found...
  ❯ Running linters...
    ❯ Running tasks for src/**/*.{js,vue}
      ✖ eslint --fix
        git add
....
....
husky > pre-commit hook failed (add --no-verify to bypass)

命令行已经提示了,add --no-verify to bypass

git commit -m "备注" --no-verify

fatal: unable to access 'https://git.aaa.bb/xxx/xxx.git/': Failed to connect to git.aaa.bb port 443: Operation timed out

执行git pull 时报错,看了下gitlab的项目地址是带端口号的

# 修改远程仓库地址,加上对应的端口号
$ git remote set-url origin https://git.aaa.bb:端口号/xxx/xxx.git

相关链接:

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

推荐阅读更多精彩内容