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
相关链接:
- Git简明指南
- Git 完整命令手册地址:http://git-scm.com/docs
- PDF 版命令手册:http://www.runoob.com/manual/github-git-cheat-sheet.pdf
- https://git-scm.com/book/zh/v2
- http://www.runoob.com/git/git-basic-operations.html
- http://www.ruanyifeng.com/blog/2014/06/git_remote.html
- https://www.cnblogs.com/cheneasternsun/p/5952830.html