1. git init - 初始化仓库
要使用 Git 进行版本管理,必须先初始化仓库。Git 是使用 git init 命令进行初始化的。实际建立一个目录并初始化仓库。
mkdir git-tutorial
cd git-tutorial
git init
strong@foreverstrong:~$ cd github_work/
strong@foreverstrong:~/github_work$ ll
total 12
drwxrwxr-x 3 strong strong 4096 Dec 17 14:04 ./
drwxr-xr-x 44 strong strong 4096 Dec 17 14:03 ../
drwxrwxr-x 4 strong strong 4096 Dec 17 14:52 Hello-World/
strong@foreverstrong:~/github_work$ mkdir git-tutorial
strong@foreverstrong:~/github_work$ cd git-tutorial/
strong@foreverstrong:~/github_work/git-tutorial$ git init
Initialized empty Git repository in /home/strong/github_work/git-tutorial/.git/
strong@foreverstrong:~/github_work/git-tutorial$ ll
total 12
drwxrwxr-x 3 strong strong 4096 Dec 17 18:46 ./
drwxrwxr-x 4 strong strong 4096 Dec 17 18:45 ../
drwxrwxr-x 7 strong strong 4096 Dec 17 18:46 .git/
strong@foreverstrong:~/github_work/git-tutorial$
如果初始化成功,执行了 git init 命令的目录下就会生成 .git 目录。这个 .git 目录里存储着管理当前目录内容所需的仓库数据。
在 Git 中,我们将这个目录的内容称为 “附属于该仓库的工作树”。文件的编辑等操作在工作树中进行,然后记录到仓库中,以此管理文件的历史快照。如果想将文件恢复到原先的状态,可以从仓库中调取之前的快照,在工作树中打开。开发者可以通过这种方式获取以往的文件。
2. git status - 查看仓库的状态
git status 命令用于显示 Git 仓库的状态。
工作树和仓库在被操作的过程中,状态会不断发生变化。在 Git 操作过程中时常用 git status 命令查看当前状态。我们来实际查看一下当前状态。
git status
strong@foreverstrong:~/github_work/git-tutorial$ git status
On branch master
Initial commit
nothing to commit (create/copy files and use "git add" to track)
strong@foreverstrong:~/github_work/git-tutorial$
结果显示了我们当前正处于 master 分支下。接着还显示了没有可提交的内容。提交 (Commit) 是指 “记录工作树中所有文件的当前状态”。尚没有可提交的内容,就是说当前我们建立的这个仓库中还没有记录任何文件的任何状态。我们建立 README.md 文件作为管理对象,为第一次提交做前期准备。
touch README.md
git status
strong@foreverstrong:~/github_work/git-tutorial$ touch README.md
strong@foreverstrong:~/github_work/git-tutorial$ git status
On branch master
Initial commit
Untracked files:
(use "git add <file>..." to include in what will be committed)
README.md
nothing added to commit but untracked files present (use "git add" to track)
strong@foreverstrong:~/github_work/git-tutorial$
可以看到在 untracked files 中显示了 README.md 文件。只要对 Git 的工作树或仓库进行操作,git status 命令的显示结果就会发生变化。
3. git add - 向暂存区中添加文件
如果只是用 Git 仓库的工作树创建了文件,那么该文件并不会被记入 Git 仓库的版本管理对象当中。因此我们用 git status 命令查看README.md 文件时,它会显示在 untracked files 里。
要想让文件成为 Git 仓库的管理对象,就需要用 git add 命令将其加入暂存区 (Stage 或者 Index) 中。暂存区是提交之前的一个临时区域。
git add README.md
git status
strong@foreverstrong:~/github_work/git-tutorial$ git add README.md
strong@foreverstrong:~/github_work/git-tutorial$ git status
On branch master
Initial commit
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: README.md
strong@foreverstrong:~/github_work/git-tutorial$
将 README.md 文件加入暂存区后,git status 命令的显示结果发生了变化。可以看到,README.md 文件显示在 Changes to be committed 中了。
4. git commit - 保存仓库的历史记录
git commit 命令可以将当前暂存区中的文件实际保存到仓库的历史记录中。通过这些记录,我们就可以在工作树中复原文件。
4.1 记述一行提交信息
实际运行一下 git commit 命令。
git commit -m "First commit"
strong@foreverstrong:~/github_work/git-tutorial$ git commit -m "First commit"
[master (root-commit) 3f44bb6] First commit
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 README.md
strong@foreverstrong:~/github_work/git-tutorial$
-m 参数后的 "First commit" 称作提交信息,是对这个提交的概述。
4.2 记述详细提交信息
刚才我们只简洁地记述了一行提交信息,如果想要记述得更加详细,请不加 -m,直接执行 git commit 命令。执行后编辑器就会启动,并显示如下结果。
strong@foreverstrong:~/github_work/git-tutorial$ git commit
在编辑器中记述提交信息的格式如下:
第一行:用一行文字简述提交的更改内容
第二行:空行
第三行以后:记述更改的原因和详细内容
只要按照上面的格式输入,今后便可以通过确认日志的命令或工具看到这些记录。在以 # (井号) 标为注释的 Changes to be committed (要提交的更改) 栏中,可以查看本次提交中包含的文件。将提交信息按格式记述完毕后,请保存并关闭编辑器,以 # (井号) 标为注释的行不必删除。随后,刚才记述的提交信息就会被提交。
4.3 中止提交
如果在编辑器启动后想中止提交,请将提交信息留空并直接关闭编辑器,随后提交就会被中止。
4.4 查看提交后的状态
执行完 git commit 命令后再来查看当前状态。
git status
strong@foreverstrong:~/github_work/git-tutorial$ git status
On branch master
nothing to commit, working directory clean
5. git log - 查看提交日志
git log 命令可以查看以往仓库中提交的日志。包括可以查看什么人在什么时候进行了提交或合并,以及操作前后有怎样的差别。
git log
strong@foreverstrong:~/github_work/git-tutorial$ git log
commit 3f44bb613b0da5e24655c3ce69cb62e3befe5ae6
Author: chengyq116 <chengyq116@163.com>
Date: Sun Dec 17 18:51:14 2017 +0800
First commit
strong@foreverstrong:~/github_work/git-tutorial$
屏幕显示了刚刚的提交操作。commit 栏旁边显示的 “3f44bb……” 是指向这个提交的哈希值。Git 的其他命令中,在指向提交时会用到这个哈希值。
Author 栏中显示我们给 Git 设置的用户名和邮箱地址。 Date 栏中显示提交执行的日期和时间。再往下就是该提交的提交信息。
5.1 只显示提交信息的第一行
如果只想让程序显示第一行简述信息,可以在 git log 命令后加上 --pretty=short。这样一来开发人员就能够更轻松地把握多个提交。
git log --pretty=short
strong@foreverstrong:~/github_work/git-tutorial$ git log --pretty=short
commit 3f44bb613b0da5e24655c3ce69cb62e3befe5ae6
Author: chengyq116 <chengyq116@163.com>
First commit
strong@foreverstrong:~/github_work/git-tutorial$
5.2 只显示指定目录、文件的日志
只要在 git log 命令后加上目录名,便会只显示该目录下的日志。
如果加的是文件名,就会只显示与该文件相关的日志。
git log README.md
strong@foreverstrong:~/github_work/git-tutorial$ git log README.md
commit 3f44bb613b0da5e24655c3ce69cb62e3befe5ae6
Author: chengyq116 <chengyq116@163.com>
Date: Sun Dec 17 18:51:14 2017 +0800
First commit
strong@foreverstrong:~/github_work/git-tutorial$
5.3 显示文件的改动
如果想查看提交所带来的改动,可以加上 -p 参数,文件的前后差别就会显示在提交信息之后。
git log -p
strong@foreverstrong:~/github_work/git-tutorial$ git log -p
commit 3f44bb613b0da5e24655c3ce69cb62e3befe5ae6
Author: chengyq116 <chengyq116@163.com>
Date: Sun Dec 17 18:51:14 2017 +0800
First commit
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..e69de29
strong@foreverstrong:~/github_work/git-tutorial$
执行下面的命令,就可以只查看 README.md 文件的提交日志以及提交前后的差别。
git log -p README.md
strong@foreverstrong:~/github_work/git-tutorial$ git log -p README.md
commit 3f44bb613b0da5e24655c3ce69cb62e3befe5ae6
Author: chengyq116 <chengyq116@163.com>
Date: Sun Dec 17 18:51:14 2017 +0800
First commit
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..e69de29
strong@foreverstrong:~/github_work/git-tutorial$
git log 命令可以利用多种参数帮助开发者把握以往提交的内容。
https://yongqiang.blog.csdn.net/
(日) 大塚弘记 著, 支鹏浩, 刘斌 译. GitHub入门与实践[M]. 北京:人民邮电出版社, 2015. 1-255