1.了解git工具产生的背景知识。
git 是什么? 目前它是一种分布式版本控制系统。
那什么又是版本控制系统? 一种能自动帮助记录每次文件的改动,不仅仅是记录自己对文件的修

改变化,而且可以记录其他人对同一文件修改的变化。如果想知道某个文件的某次修改哪里,就

直接通过这种软件来查看。这种软件就是版本控制系统。
2.安装git
对于centos :yum install -y git
对于ubuntu/debian: sudo apt-get install git

3. git 工作流程
本地仓库由git维护的三颗"树" 组成
(1)第一个是你的工作目录(working directory),它持有实际文件
(2)第二个是暂存区(Index),它像个缓存区域,临时保存你的文件修改
(3)第三个是HEAD,直接最后一次提交的结果

4. 创建本地库
(1)第一步
mkdir  learngit  #创建工作目录

cd leartgit      #进入到工作目录中
(2)建立仓库:把工作目录初始为一个仓库。
git init        #Initialized empty Git repository in /root/learngit/.git/
完成后可以发现,在工作目录下生成了一个以点开头的隐藏目录.git

注意:也不一定必须在空目录下创建Git仓库,选择一个已经有东西的目录也是可以的
(3)可以文件添加到版本库(也就是可以在目录创建文件)
在工作目录里创建文件,编写文件内容。vim filename 文件创建后,可以命令将文件添加到仓

库里面。
命令一:使用命令git add告诉Git,要将某文件添加至仓库里面
git add  filename
命令二:使用命令git commit告诉Git,把文件提交到仓库:
git commit -m "wrote a readme file"  # -m 后面的""用来说明文件修改说明信息

可以使用多次git add 命令添加文件,而git commit 将一次性提交所有修改的文件

小结:初始化一个Git仓库,使用git init命令。
添加文件到Git仓库,分两步:
第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;
第二步,使用命令git commit,完成。
命令三:git status命令可以让我们时刻掌握仓库当前的状态。文件是否被修改或者文件被修改

但是没有被提交。

命令四:git diff filename
找出文件前后修改前后对比的内容

(4)版本回退
当文件内容多次被修改后,并且进行git add 和 git commit -m "" ,这会出现文件的多个版本
那么如何查文件的历史版本和当前版本呢?
命令五:git log
git log命令显示从最近到最远的提交日志,可以看文件被修改提交了几次
git log  --pretty=oneline #每个历史版本按一行输出
$ git log --pretty=oneline
3628164fb26d48395383f8f31179f24e0882e1e0 append GPL
ea34578d5496d7dd233c827ed32a8cd576c5ee85 add distributed
cb926e7ea50ad11b8f9e909c05226233bf755030 wrote a readme file
其中前面很长的字符是commit_id(版本号,一旦提交都有与之对应的版本号)
如果想要从当前的文件版本回退到历史的某个版本,该有什么命令?
在Git中,用HEAD表示当前版本,也就是最新的提交
上一个版本就是HEAD^,
上上一个版本就是HEAD^^,
前N个版本表示:HEAD~N。
命令五来了:git reset --hard
git reset --hard^ HEAD(某个版本) #复位到最近的前一个版本。当然可以
git reset --hard "commit_id"

小结:
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset

--hard commit_id。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本

明天:学习远程仓库
怎么添加远程库与怎么从远程库克隆。还有什么是分支管理、标签管理,最后是搭建git服务器。

git命令01的更多相关文章

  1. crontab 不能执行git命令问题备忘

    这问题够隐蔽,折腾了近两个小时. 命令 git checkout tagname 手工执行都正常 但在crontab运行时发现分支一直切不过去. 后来告诉是crontab默认的 path  设置和系统 ...

  2. git命令使用方法

    git安装包 http://c35.yunpan.360.cn/my/?sid=#%2F%E5%AE%89%E8%A3%85%E5%8C%85%2FGit%E5%AE%89%E8%A3%85%2F g ...

  3. Git命令使用指南

    继续git相关的东西,网上很多讲解的,但是还是喜欢这个图:(爱屋及乌,当然内容也很好,文章链接:http://me.iblogc.com/2015/01/16/Git命令使用指南/) Git是软件开发 ...

  4. 源代码管理之Git命令的使用

    目录 02.源代码管理之Git命令的使用 2.Git命令行演练-个人开发 2.1 如何学习git指令 2.2 初始化创建本地仓库 2.3 个人开发基本演练 2.4 Git的基本常识 3.Git命令行演 ...

  5. git命令使用(必备系列)

    git是一个分布式版本控制系统,得益于高效.协作和快速的项目代码管理特性几乎每一个软件开发团队都在深度使用.本篇是对git命令的介绍,涵盖了不低于95%的日常操作命令,对你有用话可以收藏一下哦. 一. ...

  6. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  7. 工作中常用的git命令

    一 常用Git命令 git clone:(区分SSH or HTTP) git init:初始化仓库 二 Git命令详解 Git Bash下,cd /c git clone,从远程Git版本库克隆一份 ...

  8. 常用 Git 命令清单

    我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下 ...

  9. 常look的Git命令

    常用的Git命令   命令  简要说明 git add 添加至暂存区 git add–interactive 交互式添加 git apply   应用补丁 git am  应用邮件格式补丁 git a ...

随机推荐

  1. django中使用第三方包实现定时任务

    # 转载请留言联系 在做主页静态化的时候,需要定时生成主页HTML,以保持数据的最新. 定时任务可以用第三方包django-crontab来实现. 附上官方文档:https://pypi.org/pr ...

  2. Codeforces 707C Pythagorean Triples(构造三条边都为整数的直角三角形)

    题目链接:http://codeforces.com/contest/707/problem/C 题目大意:给你一条边,问你能否构造一个包含这条边的直角三角形且该直角三角形三条边都为整数,能则输出另外 ...

  3. Hive分组取第一条记录

    需求 交易系统,财务要求维护每个用户首个交易完成的订单数据(首单表,可取每个用户交易完成时间最老的订单数据).举例: 简写版的表结构: 表数据: 则 财务希望汇总记录如下: uid order_id ...

  4. hive学习(二) hive操作

    hive   ddl 操作官方手册https://cwiki.apache.org/confluence/display/Hive/LanguageManual+DDL hive  dml 操作官方手 ...

  5. Sqrt(x)——二分法,防越界

    Implement int sqrt(int x). Compute and return the square root of x. 转自:http://blog.csdn.net/doc_sgl/ ...

  6. Go语言建立一个最简单的服务端点

    handlers/handlers.go package handlers import ( "encoding/json" "net/http" ) func ...

  7. tmpfs文件系统

    centos 7测试OK 创建挂载点,挂载 mkdir -p /run/testdirmount -nt tmpfs -o size=500m,mode=755 tmpfs /run/testdir

  8. 只安装自己需要的Office2016组件的方法

    转自:https://www.ithome.com/html/office/178814.htm http://www.orsoon.com/news/184524.html

  9. Bzoj3942 Censoring(KMP)

    \(KMP\)问题的核心在于数组\(next\)(或者\(pre\)/\(fail\),各种叫法),几乎所有的此类型题都是需要计算\(next\)的. 这里解释一波\(next\):即满足字符子串\( ...

  10. 第6天-javascript事件

    什么是事件 事件是用户在访问页面执行时的操作,也就是用户访问页面时的行为.当浏览器探测到一个事件时,比如鼠标点击或者按键.它可以触发与这个事件相关的JavaScript对象(函数),这些对象成为事件处 ...