最近由于项目的需要,我需要负责整个项目的托管,其中涉及到很多Git相关的命令,所以就将之前用到的git相关的命令做了一个总结和归纳。由于开发环境是Linux,所以我接下来的操作命令均针对Linux环境。

git是一个开源的分布式的版本控制系统,主要用于项目的管理。

分布式:git使用分布式管理。即每个节点关系平等,都保存完整代码,节点之间相互推送或者下载代码。

集中式:有明确的中央服务器统一管理代码,每个节点都将代码上传中央服务器或者从中央服务器下载代码。

一、git安装准备与配置

1、git安装

$ sudo apt-get install git
$ git --version 查看当前git版本

2、git的基本配置

2.1、系统中所有用户均使用的配置

命令:sudo git config --system
配置文件:/etc/gitconfig
e.g. 配置用户名
cassie@com:~$ sudo git config --system user.name Cassie
cassie@com:~$ cat /etc/gitconfig
[user]
name = Cassie

2.2、当前用户的所有项目均使用的配置

命令:git config --global
配置文件:~/.gitconfig
e.g. 配置用户邮箱
cassie@com:~$ git config --global user.email cassie@qq.com
cassie@com:~$ cat ~/.gitconfig
[user]
email = cassie@qq.com
name = 0513Cassie

2.3、只在当前项目中使用的配置

命令:git config (命令只要在git项目文件夹中执行)
配置文件:project/.git/config e.g.配置编译器
git config core.editor vscode

二、git操作

下面这种图是我在网上看到的一张关于git操作总结的一张图,下面我将按照这张图片进行一个Git相关命令行的操作总结。

![](https://user-gold-cdn.xitu.io/2018/11/2/166d3a92f4930bda?w=554&h=157&f=png&s=61714)

首先,对上图的几个概念进行讲解一下:
- 工作区(workspace):通过自己的主机操作的git目录。
- 暂存区(index):用来记录工作行为的,即所有的操作git的记录,作为一个暂时保存。
- 本地仓库(Repository):本地用来备份同步工作区内容的区域。
- 远程仓库(Remote):其他主机的git。

2.1、工作区、缓存区、本地仓库之间数据操作

初始化仓库

$ mkdir gittest
$ cd gittest
$ git init

查看工作分支的状态

$ git status
* 当工作区和仓库没有任何差异的时候不会有任何提示
* 默认工作分支为master,可以通过创建新的分支进行切换

文件提交到暂存区

$ git add [file]
$ git add * 全部提交
* 可以一次提交多个内容,中间用空格隔开
* 提交的内容可以是文件也可以是文件夹

删除暂存区的记录

删除内容为文件:
$ git rm --cached 文件名称
删除内容为文件夹:
$ git rm --cached 文件夹名称 -r

将暂存区记录的修改内容同步到本地仓库

$ git commit -m "message"

查看提交日志

$ git log
$ git log --pretty=online 日志单行显示

2.2、工作区操作

查看工作区文件和本地仓库的差别
$ git diff [file] 放弃工作区的修改
$ git checkout -- [file] 恢复本地仓库文件到工作区
$ git checkout [file]

2.3、文件移动

删除工作区文件并提交到暂存记录
$ git rm [file] 移动工作区文件并提交到暂存区
$ git mv file dir

2.4、版本控制命令

回到之前的版本
$ git reset --hard HEAD^
* HEAD后面有几个^表示回到之前的几个版本 通过commit_id回到指定的版本
$ git reset --hard commit_id 查看操作日志
$ git relog
* 获取到操作记录后可以根据commit_id去往比较新的版本

2.5、标签管理(属于本地仓库的操作)

创建标签
$ git tag v1.
*默认会在最新的commit_id 查看标签
git tag 查看所有标签
git show v2. 查看某个标签的具体信息 在某个指定的commit_id处打标签
$ git tag v1. [commit_id] 恢复标签时的状态
$ git reset --hard v1. 删除标签
git tag -d v2.

3、常见问题

3.1、git reset --hard commit_id 误操作如何回到之前的版本

注意git log 命令是查看提交日志,所以如果我们进行上面的回到之前的版本在git log里面是无法查看commit_id的,这时候我们就需要使用 git reflog命令。

注意:git reflog命令是查看操作日志的,在这里我们可以查到所以操作的详细信息,

拿到commit_id 之后,通过git reset --hard commit_id这个命令回到指定版本即可

第一篇:Git操作详解的更多相关文章

  1. 入木三分学网络第一篇--VRRP协议详解第一篇(转)

    因为keepalived使用了VRRP协议,所有有必要熟悉一下. 虚拟路由冗余协议(Virtual Router Redundancy Protocol,简称VRRP)是解决局域网中配置静态网关时,静 ...

  2. git操作详解

    前言:一般公司git的master主干与线上代码保持一致,在使用git的时候,偶尔会发生一些莫名其妙的事情,很容易导致运营事故.so- 总结一下经常使用的git命令以及git的一些小坑,方便日后查阅 ...

  3. web运维第一篇:nginx配置文件详解笔记

    #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_processes 8; #全局错误日志定义类型,[ debug | ...

  4. Python操作Mysql数据库进阶篇——查询操作详解(一)

    前面我们已经介绍了在Python3.x中如何连接一个Mysql数据库,以及怎么样对这个数据库创建一个表,增删改查表里的数据.想必大家对Mysql数据库和简单的sql语句有了一定的了解,其实sql语句博 ...

  5. 爬虫第一篇:爬虫详解之urllib.request模块

    我将urllib.request 的GET请求和POST请求两种方法做了总结 GET请求 GET请求爬取: import urllib.request import urllib.parse head ...

  6. Git远程操作详解(转)

    转自:http://www.ruanyifeng.com/blog/2014/06/git_remote.html Git远程操作详解   Git是目前最流行的版本管理系统,学会Git几乎成了开发者的 ...

  7. 转载: GIt远程操作详解

    Git远程操作详解   作者: 阮一峰 日期: 2014年6月12日 Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介 ...

  8. Git应用详解第二讲:Git删除、修改、撤销操作

    前言 前情提要:Git应用详解第一讲:Git分区,配置与日志 在第一讲中我们对Git进行了简单的入门介绍,相信聪明的你已经了解Git的基本使用了. 这一讲我们来进一步深入学习Git应用,着重介绍Git ...

  9. Git应用详解第三讲:本地分支的重要操作

    前言 前情提要:Git应用详解第二讲:Git删除.修改.撤销操作 分支是git最核心的操作之一,了解分支的基本操作能够大大提高项目开发的效率.这一讲就来介绍一些分支的常见操作及其基本原理. 一.分支概 ...

随机推荐

  1. 一个可以模拟GET,POST,PUT,DELET请求的HTTP在线工具

    一个简陋的HTTP请求工具,UI比较丑陋.0.0,可以用于接口调试. 之前在调试公司的远程接口的时候用的是curl,后来也在网上找到几种Http请求模拟的客户端程序.当时后来发现google app ...

  2. APICloud打包Vue单页应用

    APICloud新建项目后,会生成以下目录结构 其中index.html是入口文件,而vue-cli打包生成的文件是在dist目录下 ├─dist│ └─static│ ├─css│ └─js │ └ ...

  3. 事件驱动模型实例详解(Java篇)

    或许每个软件从业者都有从学习控制台应用程序到学习可视化编程的转变过程,控制台应用程序的优点在于可以方便的练习某个语言的语法和开发习惯(如.net和java),而可视化编程的学习又可以非常方便开发出各类 ...

  4. Http和Socket 优劣比较 使用场景选择_转

    转自:http://www.cnblogs.com/webwlsong/p/3198712.html 了解HTTP和Socket之前先对网络7层协议有个了解: 7 应用层6 表示层5 会话层 4 传输 ...

  5. apache占用内存高解决办法

    我用512M的vps,访问量不大,但内存占用很大,甚至宕机. 我用top,然后shitf+m发现,httpd占用内存极大.经过网上找资料设置后,用过一段时间终于没再出现内存问题了. 首先查找配置文件的 ...

  6. JSP 表单处理向服务器提交信息

    JSP 表单处理 我们在浏览网页的时候,经常需要向服务器提交信息,并让后台程序处理.浏览器中使用 GET 和 POST 方法向服务器提交数据. GET 方法 GET方法将请求的编码信息添加在网址后面, ...

  7. MS SQL 分类汇总参数 grouping(**)=1 rollup cubt

    转:http://www.111cn.net/database/mssqlserver/43368.htm 本文章介绍了关于sql多级分类汇总实现方法及数据结构,有碰到问题的同学可参考一下. 据库结构 ...

  8. 嵌入式驱动开发之sensor---sensor 图形传感器调试

    图像传感器(image sensor)复位顺序 1. 硬件复位寄存器:2. 软件复位寄存器:3. 设置时钟寄存器:4. 设置PLL倍频:5. 设置分辨率:6. 设置窗口控制:7. 设置输出顺序:8. ...

  9. 【JavaEE】Springmvc+Spring整合及example

    这一篇在前一篇Springmvc的基础上,加上Spring.Spring的主要用途叫做控制反转(依赖注入,IoC/DI)和面向切面的编程(AOP),本文只介绍IoC,因为AOP主要的应用场景是记录日志 ...

  10. android 各版本的区别

    三.Android 6.x 新增运行时权限概念 Android6.0或以上版本,用户可以完全控制应用权限.当用户安装一个app时,系统默认给app授权部分基础权限,其他敏感权限,需要开发者自己注意,当 ...