git 使用方法

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

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 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    949 引用 • 943 回帖
  • Git

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

    211 引用 • 358 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • VirtualBox

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

    10 引用 • 2 回帖 • 13 关注
  • OnlyOffice
    4 引用 • 14 关注
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 8 关注
  • 旅游

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

    93 引用 • 901 回帖
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • sts
    2 引用 • 2 回帖 • 203 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    107 引用 • 295 回帖 • 1 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 1 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 330 关注
  • SEO

    发布对别人有帮助的原创内容是最好的 SEO 方式。

    35 引用 • 200 回帖 • 23 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    289 引用 • 4492 回帖 • 657 关注
  • Outlook
    1 引用 • 5 回帖
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    150 引用 • 257 回帖 • 1 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 2 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 303 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 780 关注
  • V2Ray
    1 引用 • 15 回帖 • 4 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 1 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 414 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 165 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 66 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 184 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 625 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    197 引用 • 541 回帖 • 2 关注