参考资料:

1. https://www.linux.com/learn/tutorials/796387-beginning-git-and-github-for-linux-users/

2. https://www.howtoforge.com/tutorial/install-git-and-github-on-ubuntu-14.04/

3. https://www.digitalocean.com/community/tutorials/how-to-install-git-on-ubuntu-14-04

4. http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

☢ Ubuntu安装命令:

sudo apt-get install git

☢ 配置:

git config --global user.name "User Name"
git config --global user.email "username@example.com"

☢ 创建repository:

sudo mkdir Pocketin

cd Pocketin

sudo git init

用下边的命令可以看到一个.git的目录,该目录是Git用来跟踪管理版本库的:

ls -ah

用vim创建readme.txt文件,并输入一些内容。

sudo vim readme.txt

添加文件readme.txt到repository中(可以同时add多个文件):

sudo git add readme.txt

提交该文件到repository,“-m”是messge的意思,用以对本次提交进行说明:

sudo git commit -m "Add a readme file for testing."

☢ 提交更改:

当修改或者增删了文件,可以用下边的命令查看repository当前的状态。

sudo git status

用下边的命令“git diff”可以查看被修改文件到底被修改了什么内容:

sudo git diff readme.txt

sudo git add readme.txt

sudo git status

sudo git commit -m "Add distributed."

sudo git status

注意:git add命令是将文件修改添加到暂存区Stage中,而git commit则是将暂存区中的所有内容提交到当前分支。因此,可知GIT管理的是修改,而不是文件。

☢ 版本回滚:

用下边的命令“git log”显示由近至远的提交日志:

sudo git log

使用下边的命令可以简化显示结果,只显示一行信息:

sudo git log --pretty=oneline

GIT的commit id是由SHA1计算出来的一个用十六进制表示的庞大数字。

下边的命令会让你回到上一个版本:

sudo git reset --hard HEAD^

下边的命令会让你回到上上个版本:

sudo git reset --hard HEAD^^

下边这个命令会让你回到上20个版本:

sudo git reset --hard HEAD~

还可以直接用版本号到你制定的版本(版本号可以不用写全):

sudo git reset --hard 2a2e569c9bd589afedc5e3a3c22683c3ca64d7f3

注意:如果你回滚了,在没有关闭当前窗口的情况还是可以回到未来的某个版本的,而一旦你关闭了窗口就不好办了(还是可以回去,下边会提到)。

版本回归只是修改了HEAD指针指向的位置,所以修改起来非常快。

使用下边的命令可以查看命令历史(然后恢复到指定的版本):

sudo git reflog

题外话(关于“--”):A  --  signals the end of options and disables further option processing. Any arguments after the -- are treated as filenames and arguments.  An argument of - is equivalent to --.

☢ 撤销修改:

如果想要回到最近一次git commitgit add时的状态,可以使用下边的命令:

sudo git checkout -- readme.txt

☢ 删除文件:

在Git中,删除也是一个修改操作。你可以通过rm命令直接删除文件,然后在用“git rm”命令从版本库中删除该文件。

sudo git add test.txt

sudo git commit -m "Add test.txt."

sudo rm -f test.txt

从版本库中伤处该文件。

sudo git status
sudo git rm test.txt
sudo commit -m "Remove test.txt."

但是,如果误删了呢?你可以通过“git checkout”命令将文件恢复到最新版本(用版本库里的版本替换工作区的版本)。

sudo git checkout -- test.txt

Linux基础※※※※如何使用Git in Linux(一)的更多相关文章

  1. Linux基础※※※※如何使用Git in Linux(二)

    参考资料: 1. http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 2. Git-简 ...

  2. Linux基础学习(1)--Linux系统简介

    第一章——Linux系统简介 1.UNIX和Linux发展史: 1.1 unix发展史: (1)1965年,美国麻省理工学院(MIT).通用电气公司(GE)及AT&T的贝尔实验室联合开发Mul ...

  3. Linux基础回想(1)——Linux系统概述

    1. 什么是操作系统?它与硬件以及其它软件之间的关系是如何的? 操作系统是控制和管理计算机系统内各种硬件和软件资源.有效组织多道程序执行的系统软件(或程序集合),是用户和计算机之间的接口.详细的说: ...

  4. 大数据学习笔记之Linux基础(一):Linux初窥

    文章目录 一.Linux入门概述 1.1 概述 1.2 下载地址 1.3 Linux特点 1.4 Linux和Windows区别 二.VM安装相关 2.1 安装VMWare虚拟机 2.2 安装Cent ...

  5. linux基础-第十四单元 Linux网络原理及基础设置

    第十四单元 Linux网络原理及基础设置 三种网卡模式图 使用ifconfig命令来维护网络 ifconfig命令的功能 ifconfig命令的用法举例 使用ifup和ifdown命令启动和停止网卡 ...

  6. Linux基础教程(一)——Linux系统简介

    Linux的概述 Linux是基于Unix的开源免费的操作系统,由于系统的稳定性和安全性几乎成为程序代码运行的最佳系统环境.Linux是由Linus Torvalds(林纳斯·托瓦兹)起初开发的,由于 ...

  7. java程序员菜鸟进阶(十五)linux基础入门(三)linux用户和组管理

    我们大家都知道,要登录linux操作系统,我们必须要有一个用户名和密码.每一个用户都由一个惟一的身份来标识,这个标识叫做用户ID.系统中的每一个用户也至少需要属于一个"用户分组". ...

  8. linux基础内容学习一:linux下的分区及安装

    linux看系统版本信息 uname -a 如果显示为i386,i686则为32位系统,如果为x86_64则为64位 一块硬盘最多可以有四个主分区其中一个主分区可以用一个扩展分区替换,在这个扩展分区中 ...

  9. Linux基础学习(13)--Linux系统管理

    第十三章——Linux系统管理 一.进程管理 1.进程查看: (1)进程简介:进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源. (2)进程管理的 ...

随机推荐

  1. Linux下串口编程【转】

    本文转载自:http://blog.csdn.net/w282529350/article/details/7378388 /************声明:本人只是见到这篇文章对我帮助很大才转载的,但 ...

  2. 【python cookbook】【字符串与文本】1.针对任意多的分隔符拆分字符串

    问题:将分隔符(以及分隔符之间的空格)不一致的字符串拆分为不同的字段: 解决方案:使用更为灵活的re.split()方法,该方法可以为分隔符指定多个模式. 说明:字符串对象的split()只能处理简单 ...

  3. 161110、彻底征服 Spring AOP 之 实战篇

    Spring AOP 实战 看了上面这么多的理论知识, 不知道大家有没有觉得枯燥哈. 不过不要急, 俗话说理论是实践的基础, 对 Spring AOP 有了基本的理论认识后, 我们来看一下下面几个具体 ...

  4. 前端js,css文件合并三种方式,bat命令

    前端js,css文件合并三种方式,bat命令 前端js文件该如何合并三个方式如下:1. 一个大文件,所有js合并成一个大文件,所有页面都引用它.2. 各个页面大文件,各自页面合并生成自己所需js的大文 ...

  5. 关于sql server 2008过期导致 MSSQLSERVER服务就无法启动,手动启动就报告错误代码17051。

    1.基本现象:MSSQLSERVER服务就无法启动,手动启动就报告17051错误. 2.解决办法: 第一步:进入SQL2008配置工具中的安装中心, 第二步:再进入维护界面,选择版本升级, 第三步:进 ...

  6. POSTGRESQL9.5之pg_rman工具

    pg_rman是一款专门为postgresql设计的在线备份恢复的工具.其支持在线和基于时间点备份方式,还可以通过创建backup catalog来维护DB cluster备份信息. 看起来好像是模仿 ...

  7. 【转】Eclipse插件大全介绍及下载地址

    转载地址:http://developer.51cto.com/art/200906/127169.htm 尚未一一验证. eclipse插件大全介绍,以及下载地址 Eclipse及其插件下载网址大全 ...

  8. 20160113006 asp.net实现ftp上传代码(解决大文件上传问题)

    using System;using System.Configuration;using System.Data;using System.Linq;using System.Web;using S ...

  9. SharePoint自动化系列——创建MMS terms

    转载请注明出自天外归云的博客园:http://www.cnblogs.com/LanTianYou/ PowerShell脚本实现MMS group.termSet.terms的自动化创建: Add- ...

  10. vim中如何替换

    1) 文件内全部替换:   :%s#abc#123#g (如文件内有#,可用/替换,:%s/abc/123/g)   --注:把abc替换成123   (或者: %s/str1/str2/g 用str ...