【Git学习笔记】初始化Git仓库和版本回退
学习地址 http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
1. 初始化Git仓库
创建空目录
$ mkdir learngit
$ cd learngit
$ pwd
/d/mycode/learngit
把目录变成Git可以管理的仓库
$ git init
Initialized empty Git repository in d:/mycode/learngit/.git/
2. 添加文件到Git仓库
在 learngit 创建 readme.txt文件,内容是
Git is a version control system.
Git is free software.
然后
$ git add readme.txt
$ git commit -m "wrote a readme file"
[master (root-commit) 01f8c13] wrote a readme file
1 file changed, 2 insertions(+)
create mode 100644 readme.txt
3. 查看工作区状态和文件修改内容
修改的 readme.txt内容为:
Git is a distributed version control system.
Git is free software.
git status 命令可以让我们时刻掌握仓库当前的状态
$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory) modified: readme.txt no changes added to commit (use "git add" and/or "git commit -a")
git diff 命令查看文件具体修改内容
$ git diff readme.txt
diff --git a/readme.txt b/readme.txt
index d8036c1..013b5bc 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a version control system.
+Git is a distributed version control system.
Git is free software.
\ No newline at end of file
版本回退
将上面的修改上传到git仓库中,经过n次的修改和上传后,git仓库已经有好多的版本了。
git log 命令用来查看上传日志
$ git log
commit ce0986a8d1603fdeeb68e66b54ab7f696e4a602f
Author: liuchuanwei <1254428526@qq.com>
Date: Wed Dec 14 14:50:17 2016 +0800 modify readme.txt commit 01f8c13a493c3fe08c7bdfceb22a19a0b5f20189
Author: liuchuanwei <1254428526@qq.com>
Date: Wed Dec 14 14:31:19 2016 +0800 wrote a readme file
如果嫌输出的信息太多太杂乱,可以是添加参数 --pretty=oneline
$ git log --pretty=oneline
ce0986a8d1603fdeeb68e66b54ab7f696e4a602f modify readme.txt
01f8c13a493c3fe08c7bdfceb22a19a0b5f20189 wrote a readme file
git reset --hard HEAD^ 回退到上一个版本,如果回退到上上个版本,则 HEAD^^ ,当然往上100个版本写100个^比较不容易数过来,所以写成HEAD~100。
$ git reset --hard HEAD^
HEAD is now at 01f8c13 wrote a readme file
这时再用 git log 命令来查看版本,发现版本 modify readme.txt 不见了,就好像你从21世纪坐时光穿梭机来到了19世纪,想再回去已经回不去了,肿么办?
$ git log
commit 01f8c13a493c3fe08c7bdfceb22a19a0b5f20189
Author: liuchuanwei <1254428526@qq.com>
Date: Wed Dec 14 14:31:19 2016 +0800 wrote a readme file
办法还是有的,只要找到版本 modify readme.txt 的commit_id ,即 ce0986a... ,它是用SHA1计算出的数字,用十六进制表示
git reset --hard comit_id 回到指定 commit_id 的版本,commit_id 不用写全,只要git能确定版本就行
$ git reset --hard ce0986
HEAD is now at ce0986a modify readme.txt
要重返未来,用 git reflog 查看命令历史,以便确定要回到未来的哪个版本。
$ git reflog
ce0986a HEAD@{0}: reset: moving to ce0986
01f8c13 HEAD@{1}: reset: moving to HEAD^
ce0986a HEAD@{2}: reset: moving to ce0986
01f8c13 HEAD@{3}: reset: moving to HEAD~1
ce0986a HEAD@{4}: reset: moving to ce0986
01f8c13 HEAD@{5}: reset: moving to HEAD^
ce0986a HEAD@{6}: commit: modify readme.txt
01f8c13 HEAD@{7}: commit (initial): wrote a readme file
【Git学习笔记】初始化Git仓库和版本回退的更多相关文章
- Git学习笔记day01 从GitHub克隆版本库
本期Git教程将会带您进入Git的世界,这是您使用分布版本控制工具Git的开端,祝您学习顺利! 步骤一 在Linux系统中下载Git 如果是Ubuntu系统,在shell中输入指令 sudo apt ...
- Git学习笔记(2)-创建仓库
一.Git简介 1.Git是什么 Git是分布式版本控制系统 2.Git有什么特点 (1)Git是分布式的SCM,SVN是集中式的 (2)Git每个历史版本存储完整的文件,SVN存储文件差异 (3)G ...
- 【Git学习笔记】远程仓库
第一种情景:本地初始化一个Git仓库后,接着又在github上创建了一个Git仓库,现在要让这两个仓库进行远程同步. 1. 关联本地仓库就和远程仓库 $ git remote add origin ...
- Git学习笔记——一个NB的分布式版本控制系统
1. 命令: git init 创建新仓库 (在一个空文件下然后执行命令) git clone + 路径 检出仓库,从本地或从服务器上 git status 查 ...
- git学习笔记04-将本地仓库添加到GitHub远程仓库-git比svn先进的地方
第1步:创建SSH Key.在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步. 如果没有,打开Shel ...
- git学习笔记(二)—— 创建版本库&&版本管理
一.创建版本库 创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录: mkdir gitHub_CXWcd gitHub_CXW git init Initialized empty G ...
- Git学习笔记四--远程仓库
Git远程仓库 Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上. 怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本 ...
- git 学习笔记 —— 切换和恢复提交版本( git reset/reflog/tag 命令)
记录一下关于 git 不同提交版本间切换的操作以及如何恢复至切换之前的版本. 切换到之前提交的版本 —— git reset --hard 笔者在使用 git 时,首先接触到了一个"黑魔法& ...
- Git学习笔记3-远程仓库
1.添加远程仓库 $ git remote add [shortname] [url] $ git remote add origin https://github.com/Mike199201/Gi ...
- Git 学习笔记--1.Git基础操作
取得项目的Git仓库 有两种方式取得Git项目仓库.第一种是在现存的目录下,通过导入所有文件来创建新的Git仓库.第二种是从已有的Git仓库克隆出一个新的镜像仓库. 在工作目录中初始化新仓库 要对现 ...
随机推荐
- canvas案例——画时钟
基本思路,先画一个200半径的圆 ctx.arc(250,250,200,0,2*Math.PI); 然后再画时分刻度,可以先利用translate变化坐标到圆的中心点,然后再通过rotate旋转 / ...
- 【Maven】解决缺少Jar包问题
解决办法:进入项目的根目录(即 pom.xml文件所在的目录)执行:mvn dependency:copy-dependencies完成后进入eclipse,发现项目不再报错前提条件:1,安装了mav ...
- DNS解析过程和域名收敛、域名发散、SPDY应用
前段时间项目要做域名收敛,糊里糊涂的完成了,好多原理不清晰,现在整理搜集下知识点. 域名收敛的目的是什么?简单来说就是域名解析慢.那为什么解析慢?且听下文慢慢道来. 什么是DNS? DNS( Doma ...
- 在react native用到的javascript 的一些关键知识(整理中)
发现了一个讲解javascript的好网站,分享一下,讲的非常棒! 注意,这些文章都可以选择中文进行阅读! 下面这个连接是关于prototype的: https://developer.mozilla ...
- Windows下几款免费C/C++开发工具简介
我相信作为编程初学者,我们都希望有好用的编程软件.这里"好用"应该至少要满足两点:1.安装简单,2.使用方便.大神移驾,对工具有特殊偏好跳过,从来不用Windows的止步.本文不做 ...
- plist文件的读写
参考资料 http://blog.csdn.net/totogo2010/article/details/7634185
- Socket通信原理探讨(C++为例)
一.网络中进程之间如何通信? 本地的进程间通信(IPC)有很多种方式,但可以总结为下面4类: 1.消息传递(管道.FIFO.消息队列) 2.同步(互斥量.条件变量.读写锁.文件和写记录锁.信号量) 3 ...
- Word2vec多线程(tensorflow)
workers = [] for _ in xrange(opts.concurrent_steps): t = threading.Thread(target=self._train_thread_ ...
- 【MongoDB】5.MongoDB与java的简单结合
1.首先 你的清楚你的MongoDB的版本是多少 就下载对应的架包 下载地址如下: http://mongodb.github.io/mongo-java-driver/ 2.新建一个项目 把架包 ...
- 《DSP using MATLAB》示例Example5.16
代码: x1 = [1,2,2,1]; x2 = [1,-1,-1,1]; x3 = conv(x1,x2); % N = 5 n1 = 0:1:length(x1)-1; n2 = 0:1:leng ...