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

可以用这个网站(learngitbranching),借助一些图形化的演示和实操功能, 使用 git 命令加深印象

命令

git config

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

$ 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 config core.ignorecase false #设置为区分大小写
复制代码

git clone

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

git pull / git fetch

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

# 取回 origin 主机的 master 分支,与本地的 dev 分支合并
$ git pull origin master:dev 

# 取回 origin/master 分支,再与当前分支合并
$ git pull origin master 
# 上一条命令实质上等同于先 git fetch,再 git merge
$ git fetch origin
$ git merge origin/master

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

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

# 取回 origin 主机的 master 分支更新
$ git fetch origin master 
复制代码

git checkout

# 切换本地分支
$ git checkout branchname

# 切换远程分支
$ git fetch --all
$ git checkout -b 本地分支名 origin/远程分支名

# 放弃所有工作区的修改
$ git checkout . 

# 放弃对指定文件的修改
$ git checkout -- filename

# 放弃工作区和暂存区的所有修改
$ git checkout -f

# 取文件 file_name 在commit_id 版本 
$ git checkout commit_id file_name 

# 在当前分支上 取出 tag_name 的版本 
$ git checkout tag_name 

# 放弃当前对文件file_name的修改
$ git checkout master file_name  
复制代码

git branch

# 创建分支
$ git branch branchName

# 切换分支
$ git checkout mybranch

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

# 查看本地分支
$ git branch

# 查看远程分支
$ git branch -a

# 修改本地分支名称
$ git branch -m old_branch new_branch 

# 删除本地分支
$ git branch -d branchName

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

# 修改本地分支以及远程分支名称
$ git branch -m old_branch new_branch
$ git push origin :old_branch
$ git push --set-upstream origin new_branch 
复制代码

git switch - git 2.23 版本新增

git restore - git 2.23 版本新增

git status

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

git status -s : 简短输出

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 commit

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

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

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

git push

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

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分支
复制代码

❌ :您尚未结束您的合并(存在 MERGE_HEAD)请在合并前先提交您的修改

解决办法:

$ git merge --abort
$ git reset --merge
# 之后再git merge就行了
复制代码

git log

# 可以用 alias.lg 对命令进行别名设置
$ git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --date=relative"
# 使用下面的命令就可以达到这一大长传的显示输出
$ git lg --all
复制代码

git remote

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

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

git diff

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

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

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

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

git diff --staged

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 reset

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

常见问题解决

文件追踪

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 
复制代码

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

修改.git/info/exclude文件

撤销操作

撤销 add

#撤销所有add文件 
$ git reset HEAD . 

#撤销单个add文件
$ git reset HEAD -filename  
复制代码

撤销 commit

$ git log #可查看提交记录

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

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

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

撤销 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 branch -m old_branch new_branch

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

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

git 跨仓库迁移、合并分支

  • 迁移A仓库test分支到B仓库
  • 合并A仓库testA分支到B仓库testB分支

无论怎样都是要在源仓库源分支去操作,在A仓库对应分支,拉取最新代码,添加B仓库为推送代码的远程仓库

$ git remote add originB B仓库的地址 # 此时在A仓库对应分支
$ git remote -v # 显示所有远程仓库,可以看到除了默认的 origin 还有 originB
复制代码
  • 迁移A仓库test分支到B仓库,在test分支下继续执行
$ git push originB test #可以看到B仓库多了个分支test,提交记录保留了下来
复制代码
  • 合并A仓库testA分支到B仓库testB分支:
$ git fetch originB #拉取目标仓库代码
$ git checkout -b testB originB/testB #检出目标分支
$ git merge testA --allow-unrelated-histories 
$ git push originB testB #可以去远程仓库看下提交记录
复制代码

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

$ git subtree push --prefix=dist origin gh-pages 
复制代码

git log 如何退出操作

Q

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

www.cnblogs.com/ballwql/p/3…

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

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
复制代码

报错处理

gitee remote: [session-f74028a4] Access denied

无法访问 'gitee.com/xxxxx/':The requested URL returned error: 403

$ git config --system --unset credential.helper
复制代码

重新输入账号密码 应该就能解决

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 '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
复制代码

相关链接

分类:
前端
标签: