1、初次使用git必用命令
git config 第一次使用git或者刚安装的git时,使用此命令设置身份Name 和 Eamail 地址。并且每次提交时会使用此信息
git config --global user.name "用户名"
git config --global user.email 邮箱
git version 检查当前使用的git版本号
2、操作远程仓库命令
git init 初始化仓库创建新项目使用该命令进行项目初始化,创建一个空白的存储库,用于存储源代码
git clone 克隆存储库命令,将远程仓库代码克隆到本地
git clone 和git init区别
git clone ” 远程仓库url “
git add 命令会把所有的代码文件或修改后的文件添加到存储库中。此命令提供了添加文件和文件夹的不同选项。
git add *
git add .
git add -u .
git add -A .
git add *.html
git add *.txt
git add index/
git add index/index.html
git commit 将工作区内容或暂存区内容提交到版本库
git commit
git commit [file1] [file2] [...]
git commit -m [message]
git commit -am [message]
git commit
git status 显示暂存区文件和当前 HEAD 提交之间有差异的路径,工作区和暂存区文件之间有差异的路径,以及工作区中没有被 Git 跟踪的路径 (也没有被 gitignore 忽略) 。
git status [<选项> …] [--] [<路径名> …] //[ ] 表示可选,...表示可以有多项。
git branch 命令主要用来处理跟分支有关系的功能,比如创建分支、删除分支、查看本地分支、查看远程分支等
git branch
git branch -v
git branch -vv
git branch -vv -a
git branch -r
git branch -d (branchName)
git push -d git push --delete git push :<分支名> //删除远程分支
git checkout (branchName) //切换本地分支
git branch (branchName) //创建本地分支git checkout -b (branchName) //创建本地分支并切换
git push <远程主机名> <本地分支名>:<远程分支名> //创建远程分支
git checkout 本意是检出的意思,也就是将某次commit的状态检出到工作区;所以它的过程是先将HEAD
指向某个分支的最近一次commit,然后从commit恢复index,最后从index恢复工作区。
git checkout (branchName)
git checkout -b (branchName)
3、git进阶
git remote 如果需要与远程仓库链接,必须使用此命令。此命令会将本地存储库连接到远程。
git remote
git remote -v | --verbose
git remote add url
git remote rm name
git remote rename old_name new_name
git push 令用于从将本地的分支版本上传到远程并合并
git push : //将本地的分支版本上传到远程并合并
git push //如果本地分支名与远程分支名相同,则可以省略冒号
以下命令将本地的 master 分支推送到 origin 主机的 master 分支
$ git push origin master === git push origin master:master
如果本地版本与远程版本有差异,但又要强制推送可以使用 --force 参数
$ git push --force origin master
删除主机的分支可以使用 --delete 参数,以下命令表示删除 origin 主机的 master 分支
$ git push origin --delete master
git push --set-upstream 先把本地的当前分支推送到远程仓库origin的main分支,然后把本地的当前分支关联到远程仓库origin的main分支
git push --set-upstream <remote> <branch>
git fetch 是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中
git fetch <远程主机名> //这个命令将某个远程主机的更新全部取回本地
如果只想取回特定分支的更新,可以指定分支名
git fetch <远程主机名> <分支名> //注意之间有空格
git pull 取回远程主机某个分支的更新,再与本地的指定分支合并
git pull [options] [
[…]]
$ git pull :<本地分支名>
要取回origin主机的next分支,与本地的master分支合并,需要写成下面这样
$ git pull origin next:master
如果远程分支(next)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再执行git merge。
$ git fetch origin
$ git merge origin/next
在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。Git也允许手动建立追踪关系
$ git branch --set-upstream master origin/next
上面命令指定master分支追踪origin/next分支。如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名
$ git pull origin
上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。如果当前分支只有一个追踪分支,连远程主机名都可以省略
$ git pull
上面命令表示,当前分支自动与唯一一个追踪分支进行合并。如果合并需要采用rebase模式,可以使用–rebase选项。
$ git pull --rebase :<本地分支名>
git fetch和git pull的区别
git fetch:相当于是从远程获取最新版本到本地,不会自动合并。
git pull:相当于是从远程获取最新版本并merge到本地
git stash 会把所有未提交的修改(包括暂存的和非暂存的)都保存起来,用于后续恢复当前工作目录
git stash save "test-cmd-stash"
git stash pop
git stash apply
git stash drop
git stash show
git log 查看所有之前的提交,最近的提交出现在最前面。
git log [<options>] [<since>..<until>] [[--] <path>...]
常用参数
-p
:
按补丁格式显示每个更新的差异,比下一条--stat
命令信息更全。
--stat
:
显示每次提交修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计。
--shortstat
:
只显示--stat
中最后的行数添加、修改、删除的统计。
--name-only
:
仅在提交信息后,显示已修改的文件清单。
--name-status
:
显示新增、修改、删除的文件清单。
--abbrev-commit
:
仅显示SHA-1
校验和的前几个字符,而非所有的40个字符。
--relative-date
:
使用较短的相对时间,而不是完整格式显示日期(比如“2 weeks ago”
)。
--graph
:
在日志旁以ASCII
图形显示分支与合并历史。
--online
:
列表的形式查看历史版本记录,--pretty=oneline --abbrev-commit
合用的简写。
--pretty
:
使用其他格式显示历史提交信息。
可用的选项包括oneline
、short
、full
、fuller
和 format
(用来定义自己的格式)
git shortlog 命令会显示来自 git log 命令的摘要。如果只对简短的摘要感兴趣,此命令就非常有用了。
git shortlog [<options>] [<revision range>] [[--] <path>…]
git log --pretty=short | git shortlog [<options>]
4、git高级命令
git rebase 可以提取我们在A分支上的改动,然后应用在B分支的代码上
git rebase -i [startpoint] [endpoint]
git rebase和git rebase
git merge
:当需要保留详细的合并信息的时候建议使用,特别是需要将分支合并进入master
分支时
git rebase
:当发现自己修改某个功能时,频繁进行了git commit
提交时,发现其实过多的提交信息没有必要时使用,分支多,内容多时也可以考虑使用
git bisect 命令可以帮助查找糟糕的提交。
git bisect <subcommand> <options>
git cherry-pick "挑拣"提交,它会获取某一个分支的单笔/多笔提交,并作为一个新的提交引入到你当前分支上
git cherry-pick //将指定的提交(commit)应用于其他分支
转移多个提交
git cherry-pick
转移到另一个代码库
git remote add target git://gitUrl
上面命令添加了一个远程仓库target。然后,将远程代码抓取到本地。
git fetch target
上面命令将远程代码仓库抓取到本地。接着,检查一下要从远程仓库转移的提交,获取它的哈希值
git log target/master
最后,使用git cherry-pick命令转移提交
git cherry-pick
git blame 追溯一个指定文件的历史修改记录
git blame [filename]
git blame的具体显示格式是
commit ID (代码提交作者 提交时间 代码位于文件中的行数) 实际代码
git tag 主要用于发布版本的管理,一个版本发布之后,我们可以为git打上 v.1.0.1 v.1.0.2 ...这样的标签
git tag //创建本地tag
git push origin //推送到远程仓库
若存在很多未推送的本地标签,你想一次全部推送的话:
git push origin --tags
以上是基于本地当前分支的最后的一个commit 创建的 tag ,但是如果不想以最后一个,只想以某一个特定的提交为tag ,也是可以的,只要你知道commit 的id。
git log --pretty=oneline //查看当前分支的提交历史 里面包含 commit id
git tag -a
git show
查看本地所有 tag:
git tag 或者 git tag -l
查看远程所有 tag:
git ls-remote --tags origin
本地 tag 的删除:
git tag -d
远程 tag 的删除:
git push origin :refs/tags/
git verify-commit 使用 GPG、SSH 或 S/MIME,您可以在本地对标签和提交进行签名
git verify-commit <commit>
git verify-tag 检查标签的 GPG 签名
git verify-tag [--format=<format>] <tag>…
git diff 比较文件的差异
情景一:查看工作区和暂存区之间文件的差异
git diff 命令,默认查看的就是 工作区 和 暂存区之间文件的差异
1.git diff : 查看工作区和暂存区之间所有的文件差异
2.git diff
3.git diff
【注意】:查看具体文件的时候
情景二:查看工作区和版本库之间文件的差异git diff HEAD : 查看工作区与最新版本库之间的所有的文件差异
git diff 具体某个版本 : 查看工作区与具体某个提交版本之间的所有的文件差异
git diff HEAD
git diff HEAD
git diff 具体某个版本
git diff 具体某个版本
情景三:查看暂存区和版本库之间文件的差异git diff
git diff
git diff
git diff
情景四:查看不同版本库之间文件的差异git diff 版本号1 版本号2 :查看两个版本之间的差异
git diff 版本号1 版本号2
git diff 版本号1 版本号2
git diff 版本号1 版本号2 src : 查看两个版本之间的文件夹 src 的差异
git citool 基于 Tcl / Tk 的图形界面用于查看修改后的文件,将它们放入索引,输入提交消息并将新提交记录到当前分支。该接口是交互程序较少的替代git commit
方案
链接:https://juejin.cn/post/7310034974424629300
(版权归原作者所有,侵删)