本文是参考廖雪峰老师的Git资料再加上我本身对Git的理解,记录个人Git学习历程,做下此文是为之后学习,工做,开发中若是遇到问题能够回过头来参考参考。由于水平有限,不免会有出错的地方,欢迎指正。前端
$git config --global user.name "你的名字"
$git config --global user.email "你的邮箱"
复制代码
global
表示全局,这台机器全部的Git仓库都会使用这个配置。容许单个仓库使用其余的名字和邮箱。node
.git
文件git init
本来本地仓库只包含着工做区,这是最多见的工做状态。此时,git init
一下,表示在本地区域建立了一个.git
文件,版本区创建。git add .
表示把工做区的全部文件所有提交到版本区里面的暂存区git add ./xxx/
一条一条分批添加到暂存区。git commit -m "xxx"
把暂存区的全部文件提交到仓库区,暂存区空空荡荡。git remote add origin https://github.com/name/name_cangku.git
把本地仓库与远程仓库链接起来。git push -u origin master
把仓库区的文件提交到远程仓库里。nothing to commit, working tree clean
之前不熟悉git命令的时候,我提交项目到github上都是直接在网页上直接拉取文件提交上去的。有点羞耻。 git
git init
.初始化,表示把这个文件变成Git能够管理的仓库。初始化后打开隐藏的文件能够看到有一个.git
文件。git add .
后面的一个点表示把这个文件所有提交到暂存区。git add ./readme.md/
表示把这个文件下面的readme.md文件提交到暂存区。git commit -m "你要评论一点什么东西"
git commit
的意思是把暂存区的所有文件提交到本地仓库。-m
后接评论。git remote add origin https://github.com/name/name_cangku.git
表示把你本地的仓库与GitHub上的远程仓库链接起来。只须要链接一次,之后提交的时候就能够不用谢这条命令了。name
是你的github名字,name_cangku
是你的仓库名。注意不要把后面的.git
给漏掉了。由于我前面就是这么走过来的,绕了不少弯路。至于如何在GitHub上新建仓库,网上有不少教程,这里再也不赘述了。git push -u origin master
把本地仓库提交到远程仓库。(最后一步)在你的远程仓库上刷新一下就能够看到你提交的文件了。git commit -m ""
以前,能够重复git add
到暂存区。可是git commit
会把你以前存放在暂存区的所有文件一次性所有提交到本地仓库。提交一个文件,有时候咱们会提交不少次,在提交历史中,这样就产生了不一样的版本。每次提交,Git会把他们串成一条时间线。如何回溯到咱们提交的上一个版本,用git reset --hard + 版本号
便可。 版本号能够用git log
来查看,每一次的版本都会产生不同的版本号。回溯以后,git log
查看一下发现离咱们最近的那个版本已经不见了。可是我还想要前进到最近的版本应该如何?只要git reset --hard + 版本号
就行。退一步来说,虽然咱们能够经过git reset --hard + 版本号
,靠记住版本号来能够在不一样的版本之间来回穿梭。可是,有时候把版本号弄丢了怎么办?git reflog
帮你记录了每一次的命令,这样就能够找到版本号了,这样你又能够经过git reset
来版本穿梭了。程序员
git checkout -- file
。廖雪峰老师指出撤销修改就回到和版本库如出一辙的状态,即用版本库里的版本替换工做区的版本。git add
到暂存区了。想撤销怎么办?回溯版本,git reset --hard + 版本号
,再git checkout -- file
,替换工做区的版本。git commit
到了master
。跟场景2同样,版本回溯,再进行撤销。git add
一个文件到暂存区,而后在工做区又把文件删除了,Git会知道你删除了文件。若是你要把版本库里的文件删除,git rm
而且git commit -m "xxx"
.git checkout --<file>
就能够。这再次证实了撤销命令其实就是用版本库里的版本替换工做区的版本,不管工做区是修改仍是删除,均可以“一键还原”。分支,就像平行宇宙,廖雪峰老师如是说。你建立了一个属于你本身的分支,别人看不到,还继续在原来的分支上正常工做,而你在本身的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工做。github
git push -u origin master
提交就是增长一条时间轴,master也会跟着移动。
理论分析完,看一下命令怎么写。面试
other
,切换到other
分支。git branch other
git checkout other
复制代码
git branch
复制代码
* other
master
复制代码
当前的分支会有一个*
安全
other
提交git add ./xxx/
git commit -m "xxx"
复制代码
other
分支完成,切换回master
git checkout master
复制代码
other
的文件,由于分支尚未合并。git merge other
复制代码
other
分支。git branch -d other
复制代码
other
已经
commit
了,
可是此时指针指回
master
时,而且
master
没有合并,而是
git add / commit
提交了。这样,就产生了冲突,主分支
master
文件内容与
other
分支的内容不同。合并不起来!因此,
git add
git commit
提交。git log --graph
查看分支合并图git branch -d other
删除分支,任务结束。git merge --no-ff other
禁用Fast forward
模式,由于使用Fast forward
模式,删除分支后,分支历史信息会丢失。廖雪峰老师提到,工做中每一个bug均可以经过一个新的临时分支来修复,修复后,合并分支,而后将临时分支删除。但若是你手上有分支在工做中,你的上级要你改另外的分支的BUG。你要把如今正在工做的分支保存下来,
git stash
,把当前工做现场“存储”起来,等之后恢复后继续工做。当你解决BUG后,git checkout other
回到本身的分支。用git stash list
查看你刚刚“存放”起来的工做去哪里了。此时你要恢复工做:bash
git stash apply
恢复却不删除stash
内容,git stash drop
删除stash
内容。git stash pop
恢复的同时把stash内容也删了.git stash list
查看,看不到任何stash
内容。git branch -d + 分支
有可能会删除失败,由于Git会保护没有被合并的分支。git branch -D + 分支
强行删除,丢弃没被合并的分支。git remote
查看远程库的信息,会显示origin
,远程仓库默认名称为origin
git remote -v
显示更详细的信息git push -u origin master
推送master
分支到origin
远程仓库。git push -u origin other
推送other
到origin
远程仓库。git pull
把最新的提交从远程仓库中抓取下来,在本地合并,解决冲突。在进行git pull
git pull
也失败了,还要指定分支之间的连接,这一步Git会提醒你怎么作。而后再git pull
。
廖雪峰老师的总结:多人协做的工做模式一般是这样:app
首先,能够试图用git push origin <branch-name>
推送本身的修改;分布式
若是推送失败,则由于远程分支比你的本地更新,须要先用git pull
试图合并;
若是合并有冲突,则解决冲突,并在本地提交;
没有冲突或者解决掉冲突后,再用git push origin <branch-name>
推送就能成功!
若是git pull
提示no tracking information
,则说明本地分支和远程分支的连接关系没有建立,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>
。
git rebase
把分叉的提交历史“整理”成一条直线,看上去更直观.缺点是本地的分叉提交已经被修改过了。git push -u origin master
rebase
的目的是使得咱们在查看历史提交的变化时更容易,由于分叉的提交须要三方对比。好比一个APP要上线,一般在版本库中打一个标签(tag), 这样,就肯定了打标签的版本。未来不管何时,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。因此,标签也是版本库的一个快照。
Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针。
tag
其实就是一个让人容易记住的有意义的名字,它跟某个commit绑在一块儿。好比tag v2.1
就是把历史上的一个版本的东西叫作v2.1
步骤:
git branch
查看当前分支,git checkout master
切换到master
分支。git tag <name>
打标签,默认为HEAD
。好比git tag v1.0
commit
上的。若是想要打标签在之前的commit
上,要git log
找到历史提交的commit
id.commt id
是du2n2d9
,执行git tag v1.0 du2n2d9
就把这个版本打上了v1.0
的标签了。git tag
查看全部标签,能够知道历史版本的tag
git show <tagname>
查看标签信息。git tag -a <标签名> -m "<说明>"
,建立带说明的标签。 -a
指定标签名,-m
指定说明文字。用show
能够查看说明。git tag -d v1.0
删除标签。由于建立的标签都只存储在本地,不会自动推送到远程。因此,打错的标签能够在本地安全删除。git push origin <tagname>
推送某个标签到远程git push origin --tags
一次性推送所有还没有推送到远程的本地标签git tag -d v1.0
先删除本地标签v1.0。git push origin :refs/tags/v1.0
删除远程标签v1.0git config --global color.ui true
让Git显示颜色,会让命令输出看起来更醒目.gitignore
文件,把须要忽略的文件名填进去。Git就会自动忽略这些文件。我也在学习中遇到过这样的问题,好比node_modules
文件就能够忽略。忽略文件原则:忽略操做系统自动生成的文件,好比缩略图等; 忽略编译生成的中间文件、可执行文件等,也就是若是一个文件是经过另外一个文件自动生成的,那自动生成的文件就不必放进版本库,好比Java编译产生的.class文件; 忽略你本身的带有敏感信息的配置文件,好比存放口令的配置文件。
git add -f <file>
git check-ignore -v <file>
检查为何Git会忽略该文件。git rebase
时,你给它一个“外号”,就叫它git nb
。之后你能够经过git nb
来代替git rebase
。具体怎么转换能够去廖雪峰老师的网站看。由于水平有限,我以为先把正常的Git命令搞清楚来就很不错了。git config --global user.name "你的名字"
让你所有的Git
仓库绑定你的名字git config --global user.email "你的邮箱"
让你所有的Git
仓库绑定你的邮箱git init
初始化你的仓库git add .
把工做区的文件所有提交到暂存区git add ./<file>/
把工做区的<file>
文件提交到暂存区git commit -m "xxx"
把暂存区的全部文件提交到仓库区,暂存区空空荡荡git remote add origin https://github.com/name/name_cangku.git
把本地仓库与远程仓库链接起来git push -u origin master
把仓库区的主分支master
提交到远程仓库里git push -u origin <其余分支>
把其余分支提交到远程仓库git status
查看当前仓库的状态git diff
查看文件修改的具体内容git log
显示从最近到最远的提交历史git clone + 仓库地址
下载克隆文件git reset --hard + 版本号
回溯版本,版本号在commit
的时候与master
跟随在一块儿git reflog
显示命令历史git checkout -- <file>
撤销命令,用版本库里的文件替换掉工做区的文件。我以为就像是Git
世界的ctrl + z
git rm
删除版本库的文件git branch
查看当前全部分支git branch <分支名字>
建立分支git checkout <分支名字>
切换到分支git merge <分支名字>
合并分支git branch -d <分支名字>
删除分支,有可能会删除失败,由于Git
会保护没有被合并的分支git branch -D + <分支名字>
强行删除,丢弃没被合并的分支git log --graph
查看分支合并图git merge --no-ff <分支名字>
合并分支的时候禁用Fast forward
模式,由于这个模式会丢失分支历史信息git stash
当有其余任务插进来时,把当前工做现场“存储”起来,之后恢复后继续工做git stash list
查看你刚刚“存放”起来的工做去哪里了git stash apply
恢复却不删除stash
内容git stash drop
删除stash
内容git stash pop
恢复的同时把stash内容也删了git remote
查看远程库的信息,会显示origin
,远程仓库默认名称为origin
git remote -v
显示更详细的信息git pull
把最新的提交从远程仓库中抓取下来,在本地合并,和git push
相反git rebase
把分叉的提交历史“整理”成一条直线,看上去更直观git tag
查看全部标签,能够知道历史版本的taggit tag <name>
打标签,默认为HEAD
。好比git tag v1.0
git tag <tagName> <版本号>
把版本号打上标签,版本号就是commit
时,跟在旁边的一串字母数字git show <tagName>
查看标签信息git tag -a <tagName> -m "<说明>"
建立带说明的标签。 -a
指定标签名,-m
指定说明文字git tag -d <tagName>
删除标签git push origin <tagname>
推送某个标签到远程git push origin --tags
一次性推送所有还没有推送到远程的本地标签git push origin :refs/tags/<tagname>
删除远程标签<tagname>
git config --global color.ui true
让Git显示颜色,会让命令输出看起来更醒目git add -f <file>
强制提交已忽略的的文件git check-ignore -v <file>
检查为何Git会忽略该文件廖雪峰老师讲Git讲的通俗易懂,对小白很友好。认认真真花上两天时间去整理,会有所收获的。廖老师的我的网站传送门
欢迎访问个人博客,会分享一些技术文章,一块儿学习前端。