可以用这个网站(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 避免用户名和密码方法
#全局配置
$ 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
复制代码