git 使用方法

本贴最后更新于 2425 天前,其中的信息可能已经时移世异

git 介绍

Git 是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目,可以有效、高速的处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

git 架构

git 由三部分组成:

  • 工作区:用户工作目录

  • 暂存区 index:用户提交的工作文档暂存于此

  • 对象库 object:用户执行 commit 操作之后的文件会进入对象库。对象库中的文件可以随时进行版本回滚。
    git 工作原理:
    首先执行 git 初始化,然后会在用户目录生成一个.git 目录,其中记录的是 index 区,object 区,hook 等各种信息。当用户在工作目录编辑文档之后可以执行 git add 把文档记录到 index 区域,然后再通过 git commit 操作把 index 区域的文件同步到 object 区域,并且可以指定一个注释信息作为版本注释信息。object 中的文件是以 sha 算法进行单向加密的 hash 值,以文件名和大小等信息为 hash 计算的依据。其中前两位为目录名,后面为文件名:

    在 object 中有 HEAD 的概念,HEAD 是一个指针,永远指向当前最新的一个 commit 版本。git 实现版本的回滚就是利用 head 实现的。当需要回滚到以前的版本的时候 HEAD 会指向用户指定的版本。
    git 原理图:

    git 使用方法

    提交文件
    git add filename:用于把文件提交到 index 区域
    git commit :用户提交 index 的文件到 object 区域
    例子:

    git init develop    #创建一个develop的工作区,其中有.git目录#
    cd develop
    cp /etc/passwd /.    #拷贝/etc/passwd文件到当前工作区#
    git status    #查看当前git状态,会提示有文件需要add进行提交或者执行git rm进行删除#
    git add .    #提交当前工作区所有文件到index#
    git commit -m ‘v0.1’    #提交文件到object区域,并注释为v0.1#
    

    此时进入.git 目录的 object 目录会看到已经多了一个文件,即刚提交的文件。
    可以对文件进行多次修改,修改完成之后再次按照以上步骤提交,然后可以进行版本回滚
    版本回滚:
    git reset --hard :将 head 指向改定的提交,index 的快照内容也更改为指定提交,工作区文件变为指定版本
    git reset --soft:head 指向给定的提交,index 和工作区不受影响
    git reste --mixed:head 指向给定的提交,index 的快照也恢复到指定版本,但是工作区内容不变

    git log --graph --pretty=oneline    #查看所有的历史提交版本#
    git reset --hard ***:恢复到指定的版本,***表示可以为commit值,也可以为tag或者文件名,也可以通过相对路径表示#
    

    此时就可以恢复到以前的版本,但是有一个问题,如果想从以前版本再恢复到最新版本发现 git log 已经找不到最新的 commit 信息了,这是因为当前状态还没有 commit,不过也可以恢复,需要使用 git reflog 查看最新的 commit 信息,git reflog 会列出在 git 执行的所有操作。
    git 相对路径表示法
    HEAD^1:表示恢复到上一个提交版本
    HEAD^2:表示恢复到上两个提交版本
    HEAD~10:表示恢复到上 10 个版本

    git 多分支

    git 可以指定多个分支同时工作,比如开发工作中 master 分支通常是用于稳定版本的发布,通常还会有 develop 开发分支。通常在 develop 分支进行开发工作,开发完成之后会把 develop 分支工作的内容合并到 master 分支中去。
    git branch:列出当前的分支数目和当前使用的分支
    git branch 分支名:创建新分支
    git checkout 分支名:切换分支

    git 分支合并

    git 分支有两种合并方式,一个为 merge,一种为 rebase。
    merge 表示把指定分支合并到另一个分支,此时两个分支的内容会合二为一,不过如果分支过多会导致分支过复杂。
    rebase 表示把指定分支无缝合并到另一分支,分支变化的内容会以 pack 文件的方式存在,pack 存放的是多个分支不同的内容。从下图可以看到 rebase 会更加明晰。

    git 合并分支一般会自动完成,不过如果主分支和另一分支对一个文件同时进行了修改操作,则需要手动解决冲突再合并。合并之前需要两个分支都 commit 工作。

    #merge操作#
    git checkout master
    git merge develop    #合并develop到master
    git add .    #合并完成需要重新提交
    git commit 
    #rebase操作#
    git checkout master
    git rebase develop
    git add.
    git commit
    

    分布式 git 版本控制系统

    有多种方法可以实现此功能,比如可以采用 github 或者公司自建 gitlab 等。
    常用命令:
    git clone 分支名:克隆远程分支到本地
    git remote:显示所有的远程分支
    git push:推送当前修改的工作内容到远程分支
    git pull:将远程分支内容取下来然后和本地进行合并
    git fetch:取回远程服务器的更新
    git 本地和远程服务器的传输可以通过多种方法

  • http 或 https 协议:可以进行远程下载,但是无法做到上传

  • ssh:可以进行远程下载上传

  • git 协议:由 git-daemon 程序提供,监听在 tcp 的 9418 端口;仅支持“读”操作,无任何认证功能;
    gitlab 和 github 都支持 http 和 ssh 两种方式。

  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    915 引用 • 931 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    205 引用 • 357 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1425 引用 • 10043 回帖 • 471 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 7 关注
  • 安全

    安全永远都不是一个小问题。

    189 引用 • 813 回帖 • 1 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 10 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    90 引用 • 383 回帖 • 1 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 404 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 22 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    6515 引用 • 29287 回帖 • 247 关注
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖 • 1 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 97 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 223 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 512 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    25 引用 • 215 回帖 • 163 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖 • 1 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖 • 1 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    85 引用 • 895 回帖
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 5 关注
  • 博客

    记录并分享人生的经历。

    270 引用 • 2386 回帖 • 1 关注
  • 996
    13 引用 • 200 回帖 • 1 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    523 引用 • 4581 回帖 • 692 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖 • 3 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    7 引用 • 26 回帖 • 3 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    103 引用 • 126 回帖 • 452 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 553 关注