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

相关链接:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容