Git(二)——repository仓库

git init会初始化一个空的仓库(empty Git repository,同时在我们执行git init后会在当前目录下自动创建一个.git的目录,这个目录是Git来跟踪管理版本库的。

$ mkdir gitDemo
$ cd gitDemo
$ git init
工作目录(Working Directory)
$ touch test.txt
$ git status
On branch master

Initial commit

Untracked files:
  (use "git add <file>..." to include in what will be committed)

    test.txt

nothing added to commit but untracked files present (use "git add" to track)
暂存区(Stage 或 Index)
$ git add test.txt
$ git status
On branch master

Initial commit

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)

    new file:   test.txt
将暂存区的内容提交到本地仓库
git commit -m"init test"
[master (root-commit) c147eb0] init test
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 test.txt

git checkout

修改文件test.txt,增加文件内容123456,想在想撤销增加的文件内容,执行git checkout,但是前提条件是未执行git add 操作 文件状态处于工作区。

git checkout -- file(文件名称)

其中 --(两个横线)很重要,没有--,就变成git切换分支的命令

$ vim test.txt
$ cat test.txt
123456
$ git checkout test.txt
$ cat test.txt

git reset HEAD

修改文件内容为qwerty,同时执行了git add 操作 文件被暂时在暂存区,撤销暂存区的修改git reset HEAD 命令

$ vim test.txt
$ cat test.txt
qwerty
$ git add test.txt
$ git reset HEAD test.txt # 取消暂存区
Unstaged changes after reset:
M   test.txt
$ git checkout test.txt # 撤销修改
$ cat test.txt

取消commit修改

git reset --soft #取消了commit  
git reset --mixed(默认) #取消了commit ,取消了add
git reset --hard #取消了commit ,取消了add,取消工作区修改

HEAD表示当前版本最新提交的commitid,当前最新的提交972cc6e5fb6d6edd53fecd88f343cab46ad62cbe ,上一个版本提交就是HEAD,上上一个版本就是HEAD,当然往上10个版本写10个,当然一般我们也不这么写,可以使用HEAD~10,波浪号+数字代表要回滚多少次之前的提交。

$ git log
commit 972cc6e5fb6d6edd53fecd88f343cab46ad62cbe (HEAD -> master)
Author: baxiang <baxiang@roobo.com>
Date:   Sun Dec 23 01:04:30 2018 +0800

    rollback two

commit 7c75daeda34530e698c208a5cedfacf1f1629b11
Author: baxiang <baxiang@roobo.com>
Date:   Sun Dec 23 01:03:29 2018 +0800

    rollback first
$ git reset --hard HEAD^
HEAD 现在位于 7c75dae rollback first
$git log 
commit 7c75daeda34530e698c208a5cedfacf1f1629b11 (HEAD -> master)
Author: baxiang <baxiang@roobo.com>
Date:   Sun Dec 23 01:03:29 2018 +0800

    rollback first

代码提交恢复
git reflog 查看git的操作记录

$ git reflog
7c75dae (HEAD -> master) HEAD@{0}: reset: moving to HEAD^
972cc6e HEAD@{1}: commit: rollback two
7c75dae (HEAD -> master) HEAD@{2}: commit: rollback first

执行git reset --hard +需要回滚的commit id 又可以恢复到rollback two这条提交记录。

$ git reset --hard 972cc6e
HEAD 现在位于 972cc6e rollback two
$ git log
commit 972cc6e5fb6d6edd53fecd88f343cab46ad62cbe (HEAD -> master)
Author: baxiang <baxiang@roobo.com>
Date:   Sun Dec 23 01:04:30 2018 +0800

    rollback two

commit 7c75daeda34530e698c208a5cedfacf1f1629b11
Author: baxiang <baxiang@roobo.com>
Date:   Sun Dec 23 01:03:29 2018 +0800

    rollback first

git commit --amend

--amend 会覆盖上一回的commit修改message(内容)

$ vim test.txt
$ cat test.txt
123456
$ git add test.txt
$ git commit -m"update test file"
$ git log
commit ad1e86d2e6d14694d5965c9c53541d49bc451a72
Author: xxxx
Date:   xxxxx

    update test file

commit c147eb0517f6399895367a97ca204bd0ca4a1736
Author: xxxxx
Date:   xxxxxx

    init test
$ vim test.txt
$ cat test.txt
654321
$ git add test.txt
$ git commit --amend -m"second update"
$ git log
commit 84f20e85cd39090a8d16aecc58bcd04d8ae625a5
Author: xxxxx
Date:  xxxxx

    second update

commit c147eb0517f6399895367a97ca204bd0ca4a1736
Author: xxxx
Date:   xxxx

    init test

git rm

删除缓存区的跟踪的文件

 git rm readme
rm 'readme'
baxiangdeMacBook:gitDemo baxiang$ git status
位于分支 master
要提交的变更:
  (使用 "git reset HEAD <文件>..." 以取消暂存)

    删除:     readme

git mv

修改文件名称

git mv readme readme.md

git log

查看commit历史,同时也可以增加--oneline ,以简洁的方式查看

 $ git log --oneline
eddccf5 (HEAD -> master) delete readme
70afaaf init readme
b5b7d12 update index
501fdac js
46995cb (test) add style.css
3dccbfc add index

查看所有分支的历史记录

git log --all
commit fe52636baa64e10e5795c26dcf0434aca48dcead (HEAD -> dev)
Author: baxiang <baxiang@roobo.com>
Date:   Wed Dec 12 00:39:25 2018 +0800

    update readme

commit b5b7d12749d468627bf0afd413ba5c2dfa16beaf (master)
Author: baxiang <baxiang@roobo.com>
Date:   Wed Dec 12 00:26:53 2018 +0800

    update index

-n 加数字 只查看最近的2次提交

$ git log -n2
commit eddccf59f9308c2b9fdd4409f5d167749622c5ee (HEAD -> master)
Author: baxiang <baxiang@roobo.com>
Date:   Fri Dec 21 19:17:57 2018 +0800

    delete readme

commit 70afaaf5cfcf5f11c768a135043f345f4b464606
Author: baxiang <baxiang@roobo.com>
Date:   Fri Dec 21 13:51:18 2018 +0800

    init readme
image.png

文件差异比较

git diff 比较的是工作区和暂存区的差别

git diff
diff --git a/README.md b/README.md
index 57edfa4..2ca7848 100644
--- a/README.md
+++ b/README.md
@@ -1 +1 @@
-test git
+git note

git diff --cached 比较的是暂存区和版本库的差别

git diff --cached
diff --git a/README.md b/README.md
index 9daeafb..57edfa4 100644
--- a/README.md
+++ b/README.md
@@ -1 +1 @@
-test
+test git

git diff HEAD 可以查看工作区和版本库的差别

git diff HEAD
diff --git a/README.md b/README.md
index 9daeafb..2ca7848 100644
--- a/README.md
+++ b/README.md
@@ -1 +1 @@
-test
+git note

git stash 暂存

$ rm text.txt
$ git status
位于分支 master
尚未暂存以备提交的变更:
  (使用 "git add/rm <文件>..." 更新要提交的内容)
  (使用 "git checkout -- <文件>..." 丢弃工作区的改动)

    删除:     text.txt

修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
$ git stash
Saved working directory and index state WIP on master: 972cc6e rollback two
$ git status
位于分支 master
无文件要提交,干净的工作区

查看当前暂存记录

$ git stash list
stash@{0}: WIP on master: 972cc6e rollback two

使用git stash apply恢复,但是需要注意的是stash内容并不删除,代表着可以重复使用,你需要用git stash drop来删除

git stash apply
删除 text.txt
位于分支 master
尚未暂存以备提交的变更:
  (使用 "git add/rm <文件>..." 更新要提交的内容)
  (使用 "git checkout -- <文件>..." 丢弃工作区的改动)

    修改:     README.md
    删除:     text.txt

修改尚未加入提交(使用 "git add" 和/或 "git commit -a")

使用git stash pop 会直接删除暂存记录

$ git stash pop
删除 text.txt
位于分支 master
尚未暂存以备提交的变更:
  (使用 "git add/rm <文件>..." 更新要提交的内容)
  (使用 "git checkout -- <文件>..." 丢弃工作区的改动)

    删除:     text.txt

修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
Dropped refs/stash@{0} (c894dd4530c7826a438ec784d53d8328960b0c9c)

忽略文件

在工作区创建名称是.gitignore的文件,在GitHub的开源工程/gitignorehttps://github.com/github/gitignore提供了常用开发语言的忽略文件内容

image.png

$ echo '*.cpp' > .gitignore
$ touch test.cpp
$ git status
位于分支 master
未跟踪的文件:
  (使用 "git add <文件>..." 以包含要提交的内容)

    .gitignore

提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

未跟踪文件

$ git status
位于分支 master
您的分支落后 'origin/master' 共 1 个提交,并且可以快进。
  (使用 "git pull" 来更新您的本地分支)

未跟踪的文件:
  (使用 "git add <文件>..." 以包含要提交的内容)

    "Java/Linux\347\232\204Java\347\216\257\345\242\203\351\205\215\347\275\256.md"
    Linux/2019-01-17.md
    "Linux/Fedora\351\205\215\347\275\256.md"
    "Linux/Linux-\346\226\207\344\273\266\346\220\234\347\264\242.md"
    "Linux/Linux-\347\243\201\347\233\230\347\256\241\347\220\206.md"
    "Linux/Linux-\350\275\257\344\273\266\347\256\241\347\220\206.md"
    "Linux/Linux\342\200\224\342\200\224-\346\226\207\344\273\266\347\256\241\347\220\206.md"
    "Linux/Linux\342\200\224\342\200\224NFS.md"
    "Linux/Linux\342\200\224\342\200\224\346\225\210\347\216\207\345\267\245\345\205\267.md"
    "Linux/Linux\342\200\224\342\200\224\347\224\250\346\210\267\347\256\241\347\220\206.md"
    "Linux/Linux\347\275\221\347\273\234\347\256\241\347\220\206.md"
    "Linux/\347\275\221\347\273\234\344\274\240\350\276\223\345\215\217\350\256\256\342\200\224\342\200\224TCP.md"
    "Linux/\347\275\221\347\273\234\344\274\240\350\276\223\345\215\217\350\256\256\342\200\224\342\200\224UDP\345\215\217\350\256\256.md"
    "Linux/\347\275\221\347\273\234\345\215\217\350\256\256\342\200\224\342\200\224IP\345\215\217\350\256\256.md"
    "Linux/\347\275\221\347\273\234\345\237\272\347\241\200\347\237\245\350\257\206.md"
    Web/C&C--/
    Web/Go/
    Web/HTML/
    Web/Java/
    Web/Linux/
    Web/MachineLearning/
    "Web/MySQL\342\200\224\342\200\224\347\216\257\345\242\203\351\205\215\347\275\256.md"
    Web/Python/
    Web/iOS/

提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

对于未跟踪文件不想提交到暂存区。可以加到.gitingore 中,设置成忽略文件类型或文件目录。但有时需要清理一些临时文件和自动生成的文件,手动删除显得太麻烦,这时你可以利用 git clean 命令来帮你完成这项操作

-d   #删除未跟踪目录以及目录下的文件,如果目录下包含其他git仓库文件,并不会删除(-dff可以删除)。
-f   #如果 git cofig 下的 clean.requireForce 为true,那么clean操作需要-f(--force)来强制执行。
-i   #进入交互模式
-n   #并不实际执行删除操作,只显示出将被清理的文件列表
-X   #仅删除.gitignore里标记过的文件,那些既不被git版本控制,又不在.gitignore中的文件会被保留。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • Git常用语法 [TOC] Git简介 描述 ​ Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,...
    君惜丶阅读 3,511评论 0 13
  • git branch 查看本地所有分支 git status 查看当前状态 git commit 提交 git b...
    猿万阅读 5,053评论 1 45
  • 对待毅力,一种很好的方式是:把它当作是目标制定者和自己签订的合同,去贯彻执行。 定下一个具体目标,越具体越好,这样...
    李静_7285阅读 336评论 2 3
  • 元组(Turple)与列表类似,不同点是: 元组的元素不可修改; 元组使用圆括号(),列表使用方括号[]。 创建元...
    学习编程王同学阅读 5,872评论 0 0
  • 前年夏天正热时,重庆一老总老弟电话来:大哥,来重庆避暑吧。我差点想笑了。火炉避暑?闻所未闻。 经不住再三相邀,去了...
    东泽话职场阅读 447评论 0 7