1、 mkdir learn 创建learn文件夹(也可不用命令创建,直接右击新建即可)
cd learn进入learn文件夹
git init
把learn文件夹 变成 可以用git管理的仓库
1、添加文件到Git仓库,分两步:
-
第一步,使用命令
git add <file>
,注意,可反复多次使用,添加多个文件; -
第二步,使用命令
git commit
,完成
commit
可以一次提交很多文件,所以你可以多次add
不同的文件
git add
命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit
就可以一次性把暂存区的所有修改提交到分支
Git是跟踪修改,每次修改,如果不add
到暂存区,那就不会加入到commit
中。
2、提交修改和提交新文件是一样的两步,第一步是git add;同样没有任何输出。在执行第二步git commit
之前,我们再运行git status
看看当前仓库的状态:git status
告诉我们,将要被提交的修改,下一步,就可以使用git commit
提交了:提交后,我们再用git status
命令看看仓库的当前状态:
-
要随时掌握工作区的状态,使用
git status
命令。 -
如果
git status
告诉你有文件被修改过,用git diff
可以查看修改内容。
3、git log命令显示从最近到最远的提交日志(历史记录)
4、回退到之前的版本使用git reset
命令,在Git中,用HEAD
表示当前版本,也就是最新的提交3
,上一个版本就是HEAD^
,上上一个版本就是HEAD^^
,当然往上100个版本写100个^
比较容易数不过来,所以写成HEAD~100
。
回退到上一个版本:$ git reset --hard HEAD^
-
HEAD
指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id
。 -
穿梭前,用
git log
可以查看提交历史,以便确定要回退到哪个版本。 -
要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。
5、命令git checkout -- readme.txt
意思就是,把readme.txt
文件在工作区的修改全部撤销,这里有两种情况:
一种是readme.txt
自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
一种是readme.txt
已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit
或git add
时的状态。
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file
。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file
,就回到了场景1,第二步按场景1操作。
6、命令git rm
用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
7、Git的杀手级功能之一:远程仓库。GitHub提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。
要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git
;
关联后,使用命令git push -u origin master
第一次推送master分支的所有内容;
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master
推送最新修改;
分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作。
8、要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone 仓库地址
命令克隆。
Git支持多种协议,包括https
,但通过ssh
支持的原生git
协议速度最快。
9、查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
用git log --graph
命令可以看到分支合并图
10、分支策略
在实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master
分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
干活都在分支上,也就是说,分支是不稳定的,到某个时候,比如1.0版本发布时,再把分支合并到master
上,在master
分支发布1.0版本;
你和你的小伙伴们每个人都在分支上干活,每个人都有自己的分支,时不时地往分支上合并就可以了。
11、修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;
当手头工作没有完成时,先把工作现场git stash
一下,然后去修复bug,修复后,再git stash pop
,回到工作现场。
12、开发一个新feature,最好新建一个分支;
如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>
强行删除。
13、查看远程库信息,使用git remote -v
;
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用git push origin branch-name
,如果推送失败,先用git pull
抓取远程的新提交;
在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name
,本地和远程分支的名称最好一致;
建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name
;
从远程抓取分支,使用git pull
,如果有冲突,要先处理冲突。
项目要发布的时候,保存在master; 远程的develop分支保存大家当前的最新开发进度;其它分支都可以只在本地创建,皆为临时分支,需要上传的时候合并到develop分支
这是一种分支管理的惯用约定git经常使用的场景:1、在github创建空白项目;2、在本地创建库、3、将本地库push到远程库;4、创建develop分支;5、创建并切换到本地工作分支 6、修改本地文件 7、加入暂存区并提交到本地库 8、切换到develop分支 9、合并临时分支 10、pull develop分支(因为其它人可能修改了develop分支,我们要处理这个) 11、将临时分支合并到本地的develop分支 12、将本地的develop分支 push到远程库
git add . :他会监控工作区的状态树,使用它会把工作时的所有变化提交到暂存区,包括文件内容修改(modified)以及新文件(new),但不包括被删除的文件。选择本地的一个文件夹
git clone 远程仓库地址 远程仓库克隆到本地文件夹 但此时 这个文件夹不是git可以管理的仓库 使用git init 初始化该仓库 使之成为git可以管理的仓库