前言


Git是版本控制系统,由Linux开源社区开发。与其他的版本系统相比,Git更加快速,便捷。主要是Git存储的是快照,而非差异性比较。并且绝大数操作都是访问本地文件和资源,没有网络时也可以直接提交,等到有网时再推送到远程仓库。对于文件的历史也是直接拉取本地,瞬间完成。

背景


解决一下场景遇到的问题
业务:个人信息的需求。
Coder:码码码码码码。。。(进行中)
安全部门:怎么档案的信息改下id,能看到别人的档案,赶紧修复。
Coder:个人信息还没做好,档案修复和个人信息文件又存在交叉,不能提交,该怎么办?

文件状态变化周期



文件的状态只有两种:未跟踪(untracked)和已跟踪(unmodified、modified、staged)

1. 工作目录下创建new.php文件


执行 git status,可以发现new.php还没有被git跟踪

2. 跟踪new.php文件


执行git add . 后,文件被放入暂存区(staged)

3. 修改new.php的内容


git status 后,出现 Changes not staged for commit,说明跟踪的文件已被修改,还未放入在暂存区

4. 暂存修改的new.php


git add 是个多功能的命令,既可以将未跟踪的文件放入暂存区,也可以将修改的文件放入暂存区,当然它还有其他的一些功能。从上面的图我们可以看到,修改的文件被放入到暂存区了。

5. 提交,生成快照


git commit -m "add new" 后,已生成此次的快照,校验和为 dd90005
note : git commit -a -m ''add new", 可以跳过git add

6. 删除提交


git rm后,重新提交,文件在工作目录和暂存区中都被删除。

分支

git的原理由5个对象实现,想知道具体的可以搜下资料看看,这里主要讲如何解决背景出现的问题。
git log --oneline --decorate --graph --all //先执行此命令查看工作目录所处的分支

根据上图可以看到工作目录处于master分支,HEAD指向master分支,流程图:

1.个人信息需求

git branch issue //此时HEAD还是指向master
创建issue分支,这点很重要,当有新需求过来的时候,一定要创建自己的分支。保持主分支为原样。
git checkout issue //切换到issue分支,HEAD指向issue

流程图:

2. 码码码码码码

在issue分支下,工作,并提交到暂存区

可以看到生成了校验码为c7abbef的快照,流程图:

3. 档案信息修复

git checkout master //切换master主分支,HEAD指向master
git branch issue2 //创建issue2分支,HEAD指向master
git checkout issue2 //HEAD指向issue2
修复bug,同提交,产生3a59570快照。
此时流程图:

git checkout master //切换master分支
git merge issue2 //issue2分支的内容合并到master分支
流程图:

此时的合并只是将master指针前移。
git branch -d issue2 //删除issue2分支

4. 继续个人信息

git checkout issue //切换issue分支
码码码码码。。。。
功能实现继续提交
流程图:

git checkout master //切换到master主分支
git merge issue //合并issue分支到master主分支

此时的合并就不是简单的将master指针前移,因为这两个分支的共同分支是9ffb7ee,而不是3a59570,此次合并做了两次操作,一是将94517a9、9ffb7ee、3a59570的结果做了一次新的快照,二是对结果做了一次新的提交10af497。

注:此时如果有文件冲突,出现 CONFLICT (content): Merge conflict ,可以到冲突的文件中,修改冲突的内容,再次 git commit -a -m "fix confilct"

关于git的使用就讲到这了,上面讲的这些也只是git的基本使用。
当我们再去深入的了解的话,就会发现用git也可以实现运维系统发布那一套流程,每一个开发者将自己私有库的更新发布到自己的公共库上,再由管理者去拉取开发者的公共库更新,管理者发现没有问题,再推送到主仓库。

Git基础使用的更多相关文章

  1. [转] Git 基础 - 打标签

    2.6 Git 基础 - 打标签 打标签 同大多数 VCS 一样,Git 也可以对某一时间点上的版本打上标签.人们在发布某个软件版本(比如 v1.0 等等)的时候,经常这么做.本节我们一起来学习如何列 ...

  2. Git基础操作

    配置秘钥 1.检查本机有没有秘钥 检查~/.ssh看看是否有名为d_rsa.pub和id_dsa.pub的2个文件. $ ~/.sshbash: /c/Users/lenovo/.ssh: Is a ...

  3. git基础及分支

    关于版本控制 git是一种分布版本控制系统,每一主机都保存了完整副本.必杀技是分支. 在Windows可安装git客户端msysgit. git基础 第一次看progit觉得有点不懂,不懂版本控制,一 ...

  4. 《Pro Git》笔记2:Git基础操作

    第二章 Git基础 Git基础包括:版本库的创建和获取,文件添加修改提交等基本操作,状态查询,远程版本库管理和同步,打标签. 1.取得项目的Git版本库 基于Git的工作流要以Git版本库为基础,即可 ...

  5. Git详解之二 Git基础

    Git 基础 读完本章你就能上手使用 Git 了.本章将介绍几个最基本的,也是最常用的 Git 命令,以后绝大多数时间里用到的也就是这几个命令.读完本章,你就能初始化一个新的代码仓库,做一些适当配置: ...

  6. 2.4 Git 基础 - 撤消操作

    2.4 Git 基础 - 撤消操作 撤消操作 任何时候,你都有可能需要撤消刚才所做的某些操作.接下来,我们会介绍一些基本的撤消操作相关的命令.请注意,有些撤销操作是不可逆的,所以请务必谨慎小心,一旦失 ...

  7. ###Git 基础图解、分支图解、全面教程、常用命令###

    一.Git 基础图解 转自:http://www.cnblogs.com/yaozhongxiao/p/3811130.html Git 图解剖析 git中文件内容并没有真正存储在索引(.git/in ...

  8. 【git学习二】git基础之git管理本地项目

    1.背景        git基础打算分两部分来说,一部分是对于本地项目的管理,第二部分是对于远程代码仓库的操作. git运行本地项目管理包含对于相关文件的追踪,暂存区的比較分析,提交,撤销等功能. ...

  9. Git基础教程(二)

    继续上篇Git基础教程(一),在开篇之前,先回顾一下上篇中的基本命令. 配置命令:git config --global * 版本库初始化:git init 向版本库添加文件:git add * 提交 ...

  10. Git详解之二:Git基础

    Git 基础 读完本章你就能上手使用 Git 了(伯乐在线注:如果你对Git还不了解,建议从本Git系列第一篇文章开始阅读).本章将介绍几个最基本的,也是最常用的 Git 命令,以后绝大多数时间里用到 ...

随机推荐

  1. 本次作业统一标题:C语言I博客作业02

    这个作业属于哪个课程 C语言程序设计1 这作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/CST2019-2/homework/8655 我在这个课程的目标是 ...

  2. Vue/React圆环进度条

    数据展示,一直是各行各业乐此不疲的需求,具体到前端开发行业,则是各种各种图表数据展示,各种表格数据展示,烦不胜烦(繁不胜繁)! 前几天刚做了折线图.柱状图.饼状图之类的图表数据展示效果,今天又碰到了类 ...

  3. LitePal的基本用法

    快速配置   1. 引入Jar包或源码 首先我们需要将LitePal的jar包引入到项目当中,可以点击这里查看LitePal的最新版本,选择你需要的下载即可.下载好了jar包之后,把它复制到项目的li ...

  4. JAVA之类的动手动脑

    1.默认构造方法与自定义的构造方法的冲突 package com.xu; class fool { int value; fool(int nowvalue) { value=nowvalue; } ...

  5. SSH服务协议

    1.SSH介绍: SSH 是Secure Shell Protocol 的简写,由IETF网络小组(Network Working Group)制定:在进行数据传输之前,SSH先对联机数据包通过加密技 ...

  6. Redis之安装配置(Windows)

    下载 下载地址:https://github.com/MSOpenTech/redis/releases 解压,文件的名字重命名为redis. 打开文件夹,内容如下: 发送redis-server.e ...

  7. GUI tkinter (Canvas)绘图篇

    from tkinter import * root = Tk()root.title("中国象棋棋盘手绘") can = Canvas(root,width = 400, hei ...

  8. Python玩转人工智能最火框架 TensorFlow应用实践 ☝☝☝

    Python玩转人工智能最火框架 TensorFlow应用实践 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 全民人工智能时代,不甘心只做一个旁观者,那就现在 ...

  9. Kubernetes集群的部署方式及详细步骤

    一.部署环境架构以及方式 第一种部署方式 1.针对于master节点 将API Server.etcd.controller-manager.scheduler各组件进行yum install.编译安 ...

  10. windows自带的netsh的使用

    0x01netsh简介 自Windows XP开始,Windows中就内置网络端口转发的功能.任何传入到本地端口的TCP连接(IPv4或IPv6)都可以被重定向到另一个本地端口,或远程计算机上的端口, ...