《Git学习指南》学习笔记(一)
第二章 入门
git的安装
在Linux下,git的安装很简单。以我的系统Deepin/Ubuntu为例,只需在终端敲入sudo apt-get install git即可。其他Linux发行版可尝试yum install git-core。
第一个Git项目
初学时,建议使用一个新创建的目录来进行测试。
创建版本库
版本库可以存储项目及其历时数据。我们可以用init来进行创建。
首先我们新建一个空目录gittest,然后新建两个文本文件,如a.txt和b.txt,内容任意,然后使用init来创建版本库:
观察文件夹,可以发现已经多了一个名为.git的隐藏文件:
这样就说明你的版本库已经创建成功。
首次提交
刚刚仅仅是把版本库创建了,那我的两个文件如何添加到版本库中去呢?此时需要使用两个命令:add和commit,每次提交git都会为其生成一个散列值,这也是git对所有版本进行区分的一个键值。
如图,已经成功提交了刚刚创建的a和b两个文件。
检查状态
git如何检查版本库文件的状态呢?
首先我们来把a.txt删除,然后新建一个c.txt,最后查看状态:
status命令用于显示自上次提交以来所有发生的修改。c.txt文件被标为未跟踪状态,是因为它还没有被add进版本库。
使用diff命令可以显示每个被修改的行,但在终端上看可能会显得比较晦涩难懂:
因此还是建议使用图形化工具如kdiff3来查看。这里请大家自行查找。
提交修改
我们修改b.txt文件内容,希望将更改加入到版本库中,对希望删除的文件使用rm命令,操作之后同样也需要执行add命令,然后查看状态:
最后,别忘了commit:
显示历史
既然我们已经修改过文件了,那如何查看历史记录呢?
log命令即可按照时间降序来显示历史记录:
Git的协作功能
克隆版本库
为了模拟团队开发协作,我们另新建一个文件夹,代表第二位开发者在自己的PC上进行团队开发:
此时,gittest2中已经有一份和gittest项目一模一样的拷贝。
从另一版本库中获取修改
现在,我们假设开发者A对gittest项目进行了修改:
此时,开发者B也对项目进行了修改:
这样,两位开发者都在各自的PC上对项目进行了修改、提交。由于开发者B克隆的A的项目,因此B的项目中存储了原版本库的路径。接下来,我们使用pull命令将开发者B克隆的项目进行同步,取回最新的提交:
可以发现,开发者B的项目中的b.txt文件得到了同步,和A的一模一样了。这个过程中,B使用pull从原版本库中取回了新的修改,将它们与克隆体中的本地修改进行对比,然后在工作区中合并了两边的修改,创建了一次新的提交,这就叫合并(merge)。
从任意版本库中取回修改
在进行pull时,默认是从原版本库中进行获取。当指定参数时,便能实现从任意版本库中获取。
现在,我们将克隆体中的修改pull到原版本库:
创建共享版本库
push命令可以将提交传送给其他版本库。但是,push命令只适用于那些没有开发者在上面开展具体工作的版本库。最好是创建一个不带工作区的版本库,称为裸版本库(bare reppository)。
裸版本库就是充当开发者们传递提交的汇聚点,以便其他人可以从中拉回他们所做的修改。
用push命令上载修改
修改~/gittest/b.txt文件,然后进行提交,最后push操作:
Pull命令:取回修改
现在,clone仓库也想获取相应的修改,执行以下命令即可:
《Git学习指南》学习笔记(一)的更多相关文章
- 《Hadoop》大数据技术开发实战学习笔记(二)
搭建Hadoop 2.x分布式集群 1.Hadoop集群角色分配 2.上传Hadoop并解压 在centos01中,将安装文件上传到/opt/softwares/目录,然后解压安装文件到/opt/mo ...
- 《Hadoop大数据技术开发实战》学习笔记(一)
基于CentOS7系统 新建用户 1.使用"su-"命令切换到root用户,然后执行命令: adduser zonkidd 2.执行以下命令,设置用户zonkidd的密码: pas ...
- 超人学院Hadoop大数据技术资源分享
超人学院Hadoop大数据技术资源分享 http://bbs.superwu.cn/forum.php?mod=viewthread&tid=807&fromuid=645 很多其它精 ...
- java大数据最全课程学习笔记(1)--Hadoop简介和安装及伪分布式
Hadoop简介和安装及伪分布式 大数据概念 大数据概论 大数据(Big Data): 指无法在一定时间范围内用常规软件工具进行捕捉,管理和处理的数据集合,是需要新处理模式才能具有更强的决策力,洞察发 ...
- hadoop大数据技术架构详解
大数据的时代已经来了,信息的爆炸式增长使得越来越多的行业面临这大量数据需要存储和分析的挑战.Hadoop作为一个开源的分布式并行处理平台,以其高拓展.高效率.高可靠等优点越来越受到欢迎.这同时也带动了 ...
- 除Hadoop大数据技术外,还需了解的九大技术
除Hadoop外的9个大数据技术: 1.Apache Flink 2.Apache Samza 3.Google Cloud Data Flow 4.StreamSets 5.Tensor Flow ...
- 大数据技术之_09_Flume学习_Flume概述+Flume快速入门+Flume企业开发案例+Flume监控之Ganglia+Flume高级之自定义MySQLSource+Flume企业真实面试题(重点)
第1章 Flume概述1.1 Flume定义1.2 Flume组成架构1.2.1 Agent1.2.2 Source1.2.3 Channel1.2.4 Sink1.2.5 Event1.3 Flum ...
- 大数据技术之_19_Spark学习_01_Spark 基础解析 + Spark 概述 + Spark 集群安装 + 执行 Spark 程序
第1章 Spark 概述1.1 什么是 Spark1.2 Spark 特点1.3 Spark 的用户和用途第2章 Spark 集群安装2.1 集群角色2.2 机器准备2.3 下载 Spark 安装包2 ...
- 大数据技术之_16_Scala学习_01_Scala 语言概述
第一章 Scala 语言概述1.1 why is Scala 语言?1.2 Scala 语言诞生小故事1.3 Scala 和 Java 以及 jvm 的关系分析图1.4 Scala 语言的特点1.5 ...
- 大数据技术之_16_Scala学习_04_函数式编程-基础+面向对象编程-基础
第五章 函数式编程-基础5.1 函数式编程内容说明5.1.1 函数式编程内容5.1.2 函数式编程授课顺序5.2 函数式编程介绍5.2.1 几个概念的说明5.2.2 方法.函数.函数式编程和面向对象编 ...
随机推荐
- Spring MVC 框架
一.SpringMVC基础入门,创建一个HelloWorld程序 1.首先,导入SpringMVC需要的jar包. 2.添加Web.xml配置文件中关于SpringMVC的配置 <!--conf ...
- Google File System设计方面的问题汇总
1.Google File System概述 google file system是一个分布式文件系统,针对的是数据密集型应用,提供容错功能,运行在低廉的服务器上,同时给大量的用户提供高性能服务.尽管 ...
- linux内存管理---虚拟地址、逻辑地址、线性地址、物理地址的区别(一)
分析linux内存管理机制,离不了上述几个概念,在介绍上述几个概念之前,先从<深入理解linux内核>这本书中摘抄几段关于上述名词的解释: 一.<深入理解linux内核>的解释 ...
- uiwebview与objective-c
利用oc调用js很简单, 系统直接提供了方法stringByEvaluatingJavaScriptFromString [webView stringByEvaluatingJavaScriptFr ...
- SQL 一
1.所有表都必须在模式中.2.SYS模式不是默认模式3.虽然有概念用户PUBLIC,但它根本没有模式.4.索引有自己的名称空间,存储过程.同义词.表和视图都在同一名称空间里.5.堆是可变长度行的表,这 ...
- 严重: A child container failed during start java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component
自己写了个最简单的springMVC项目练练手,没有用maven,在WebContent中新建了lib文件夹,将jar包复制到这里面,然后add to build path到项目里. 启动Tomcat ...
- linux下pip错误 ImportError: No module named 'pip_internal'
wget https://bootstrap.pypa.io/get-pip.py --no-check-certificate sudo python get-pip.py
- 笔记: js构造函数与原型
目录 构造函数与原型介绍 涉及三种引用的操作 有关原型及原型链的一些相关方法总结 @ 构造函数与原型介绍 1.函数与函数的原型对象(prototype object): 在JavaScript中,创建 ...
- YII2集成GOAOP,实现面向方面编程!
引言: 软件开发的目标是要对世界的部分元素或者信息流建立模型,实现软件系统的工程需要将系统分解成可以创建和管理的模块.于是出现了以系统模块化特性的面向对象程序设计技术.模块化的面向对象编程极度地提高了 ...
- 【NXP开发板应用—智能插排】1.如何使用scp传输文件
首先感谢深圳市米尔科技有限公司举办的这次活动并予以本人参加这次活动的机会,以往接触过嵌入式,但那都是皮毛,最多刷个系统之类的,可以说对于嵌入式系统开发这件事情是相当非常陌生的,这次活动为我提供了一个非 ...