设为首页 收藏本站
查看: 819|回复: 0

[经验分享] 2 修改与恢复

[复制链接]

尚未签到

发表于 2017-11-20 23:53:02 | 显示全部楼层 |阅读模式
  将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

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-409025-1-1.html 上篇帖子: 搭建mxnet-gpu docker的pyhon remote kernel 下篇帖子: docker改国内官方镜像
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表