将readme.txt添加到仓库后,现在来修改它:
Git is a distributed version control system.
GIt is free software.
运行git status 或加上文件名:
位于分支 master
尚未暂存以备提交的变更:
(使用 "git add <文件>..." 更新要提交的内容)
(使用 "git checkout -- <文件>..." 丢弃工作区的改动)
修改: readme.txt
修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
运行git diff或加上文件名:
查看变更内容
diff --git a/practice/readme.txt b/practice/readme.txt
index f1dc24f..a431595 100644
--- a/practice/readme.txt
+++ b/practice/readme.txt
@@ -1,2 +1,3 @@
-Git is a version control system.
+Git is a distributed version control system. #添加了distributed
GIt is free software.
与提交新文件一样,提交修改也是两步:
$ git add readme.txt #第一步,添加,无异常,提交前先查看下状态
$ git status
位于分支 master
要提交的变更:
(使用 "git reset HEAD <文件>..." 以取消暂存)
修改: readme.txt
$ git commit -m 'add distributed' #第二步,提交,正常,再看下状态
[master ab16d2b] add distributed
1 file changed, 2 insertions(+), 1 deletion(-)
$ git status
位于分支 master
无文件要提交,干净的工作区 #ok
小结:
查看工作区状态用 git status,git diff查看修改内容
版本回退:
查看提交历史记录,由近及远:
l@ubuntu:~/learngit$ git log
commit abd8c7d5ed726202b600fa5c312ddcd111522830
Author: gitstudy <327599582@qq.com>
Date: Fri Nov 10 22:28:28 2017 +0800
append GPL
commit ab16d2b4bad7096b504266b8937390cd7f7ecf3c
Author: gitstudy <327599582@qq.com>
Date: Thu Nov 9 22:51:34 2017 +0800
add distributed
commit a6d66840e42757136a5976275c02386d849302c5 #版本号:SHA1算法 十六进制
Author: gitstudy <327599582@qq.com>
Date: Tue Nov 7 23:38:38 2017 +0800
wrote a readme file
l@ubuntu:~/learngit$ git log --pretty=oneline #简单显示
abd8c7d5ed726202b600fa5c312ddcd111522830 append GPL
ab16d2b4bad7096b504266b8937390cd7f7ecf3c add distributed
a6d66840e42757136a5976275c02386d849302c5 wrote a readme file
在Git中,当前版本:HEAD,上一版本:HEAD^,上上版本:HEAD^^,...,HEAD~n。回退至上一版本,用git reset
l@ubuntu:~/learngit$ git reset --hard HEAD^
HEAD 现在位于 ab16d2b add distributed
l@ubuntu:~/learngit/practice$ cat readme.txt
Git is a distributed version control system. #已经回退
GIt is free software.
再次回退前查看log
l@ubuntu:~/learngit$ git log --pretty=oneline #append GPL版本没了
ab16d2b4bad7096b504266b8937390cd7f7ecf3c add distributed
a6d66840e42757136a5976275c02386d849302c5 wrote a readme file
要回退至append GPL必须找到其commit id,通过git reflog查看:
l@ubuntu:~/learngit$ git reflog
ab16d2b HEAD@{0}: reset: moving to HEAD^
abd8c7d HEAD@{1}: commit: append GPL
ab16d2b HEAD@{2}: commit: add distributed
a6d6684 HEAD@{3}: commit (initial): wrote a readme file
l@ubuntu:~/learngit/practice$ git reset --hard abd8c7d
HEAD 现在位于 abd8c7d append GPL
l@ubuntu:~/learngit/practice$ cat readme.txt #回到append GPL版本
Git is a distributed version control system.
GIt is free software distributed under the GPL.
总结:
HEAD指当前版本,使用git reset --hard commit_id回退至某个版本
回退前用git log查看提交历史,确定回退的版本
用git reflog查看命令历史
工作区和暂存区
工作区(working directory):如learngit目录
版本库(repository):工作区的隐藏目录 .git不算工作区,而是Git版本库
版本库中最重要的是stage(或index)即暂存区,还有Git给我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD
1、git add命令把文件修改添加到暂存区
2、git commit命令把暂存区的所有内容提交到当前分支即master分支,注:提交是把暂存区的所有修改一次性提交完
管理修改
Git跟踪是修改而非文件,修改都是在工作区,add的次数要大于等于修改的次数,可全部添加后统一git commit
撤销修改
1、工作区修改后还没有 add 到暂存区:手动更正
git checkout -- readme.txt 把在工作区的修改全部撤销
2、工作区修改后add到暂存区:分两步1:git reset HEAD readme.txt将暂存区修改回退至工作区,HEAD是最新版本
2:git checkout -- readme.txt
3、已经提交了不合适的修改到版本库:在没有推送到远程库的前提下,通过版本回退撤销本次提交,然后重复2的操作
删除文件
在Git中,删除也是一个修改动作,例:
先在工作区创建一个文件,添加并提交
$ touch test.txt #使用了sh 命令
$ ls
license readme.txt test.txt
$ git add test.txt
$ git commit -m 'add test.txt'
[master 818fddc] add test.txt
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 practice/test.txt
一般会在文件管理器或用rm删除没用文件
$ rm test.txt
此时Git知道有文件被删除,工作区和版本库不一致,
$ git status
位于分支 master
尚未暂存以备提交的变更:
(使用 "git add/rm <文件>..." 更新要提交的内容)
(使用 "git checkout -- <文件>..." 丢弃工作区的改动)
删除: test.txt
修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
此时有两种情况,一确实要从版本库删除文件,用git rm 删除该文件并git commit,
$ git rm test.txt
rm 'practice/test.txt'
$ git commit -m 'remove test.txt'
[master ed47d55] remove test.txt
1 file changed, 0 insertions(+), 0 deletions(-)
delete mode 100644 practice/test.txt
$ git status
位于分支 master
无文件要提交,干净的工作区 #test.txt从版本库删除,在工作区也已经被删了
二误删,从版本库中的最新版提取到工作区,
git checkout -- test.txt
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com