下面内容总结于菜鸟教程:https://www.runoob.com/git/git-workflow.html
补充:1) cat 文件名:显示文件内容
touch 文件:生成新的文件
vim 文件:查看文件,修改文件
1.git一般工作流程:
- 克隆 Git 资源作为工作目录。
- 在克隆的资源上添加或修改文件。
- 如果其他人修改了,你可以更新资源。
- 在提交前查看修改。
- 提交修改。
- 在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。
2.Git 工作区、暂存区和版本库
-
图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage/index),标记为 "master" 的是 master 分支所代表的目录树。
-
图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
-
图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。
-
当对工作区修改(或新增)的文件执行 git add 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。
-
当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
-
当执行 git reset HEAD 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。
-
当执行 git rm --cached <file> 命令时,会直接从暂存区删除文件,工作区则不做出改变。
-
当执行 git checkout . 或者 git checkout -- <file> 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除暂存区中未添加到工作区中的改动。
-
当执行 git checkout HEAD . 或者 git checkout HEAD <file> 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。
3.常用操作
1)git clone
拉代码,格式一:git clone <repo> ex.: git clone git://github.com/schacon/grit.git
格式二(克隆到指定目录):git clone <repo> <directory> ex.: git clone git://github.com/schacon/grit.git mygrit
- git init - 初始化仓库。
- git add . - 添加文件到暂存区。
- git commit - 将暂存区内容添加到仓库中。
2)git add
添加文件到暂存区,格式一(添加一个或多个文件到暂存区):git add [file1] [file2] ...
格式二(添加指定目录到暂存区,包括子目录):git add [dir]
格式三(添加当前目录下的所有文件到暂存区):git add .
3)git status
查看在你上次提交之后是否有对文件进行再次修改 格式:git status -s
4)git diff
比较文件的不同,即比较文件在暂存区和工作区的差异。
格式: git diff [file]
显示暂存区和上一次提交(commit)的差异: git diff --cached [file]
5)git commit
将暂存区内容添加到本地仓库中 格式(message为备注信息):git commit -m [message]
格式(跳过git add,直接将修改提交到本地仓库):git commit -a
6)git reset
命令用于回退版本,可以指定退回某一次提交的版本 格式:git reset [--soft | --mixed | --hard] [HEAD]
$ git reset HEAD^ # 回退所有内容到上一个版本
$ git reset HEAD^ hello.php # 回退 hello.php 文件的版本到上一个版本
$ git reset 052e # 回退到指定版本
--hard 参数撤销工作区中所有未提交的修改内容,将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交:
git reset --hard HEAD
HEAD 说明:
-
HEAD 表示当前版本
-
HEAD^ 上一个版本
-
HEAD^^ 上上一个版本
-
HEAD^^^ 上上上一个版本
7)git rm
用于删除文件。
将文件从暂存区和工作区中删除:git rm <file> ex:git rm runoob.txt
如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f ex:git rm -f runoob.txt
从暂存区中删除 文件:git rm --cached runoob.txt
8) git mv
用于移动或重命名一个文件、目录或软连接.
格式:git mv [file] [newfile]
9)git log
查看历史提交记录
git reflog:查看历史版本号,可用命令git reset --hard 版本号恢复
10)远程操作
git remote | 远程仓库操作 |
git fetch | 从远程获取代码库 |
git pull | 下载远程代码并合并 |
git push | 上传远程代码并合并 |
显示所有远程仓库:git remote -v
11) git branch
查看分支,
git branch -d 分支:把分支删除
git branch 分支:创建分支
12) git checkout
git checkout 分支名:切换分支
git checkout -b 分支名:新建并切换分支
git checkout -- 文件名:丢弃工作区的修改,与git restore -- 文件名作用一致,只要没有commit之前,如果我想在版本库中恢复此文件也是用该命令
13) git merge
git merge 分支:合并指定分支到当前分支上
git merge --no-ff -m "说明" 分支名:禁用fast forward模式,删除分支后,分支信息也不会丢失。
14)git remote add origin github仓库地址
把本地仓库与之关联,若要把本地仓库的内容推送到github仓库,使用git push origin 分支名,如git push origin master.(若第一次推送,需要在push 后加-u)
15)git clone
git clone 远程分支地址:把远程仓库克隆到本机库,如 git clone https://github.com/tugenhua0707/testgit2
16) git stash
代码开发到一般时,要修复bug,需要把当前开发的状态保留下来,那么需要用git stash
开发完回到分支时,用git stash 查看分支,然后用git stash pop,恢复的同时把stash内容也删除了。