热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【git教程】git使用方法

文章目录Git简介版本库工作区暂存区本地仓库远程仓库文件状态ChangesnotstagedforcommitChangestobecommittedUntrackedfilesn


文章目录

    • Git简介
        • 版本库
        • 工作区
        • 暂存区
        • 本地仓库
        • 远程仓库
    • 文件状态
        • Changes not staged for commit
        • Changes to be committed
        • Untracked files
        • nothing to commit, working tree clean
    • 分支管理
        • 查看分支
        • 创建新分支
        • 切换分支
        • 删除分支
        • 删除远程分支
    • .gitignore
    • 基本操作


Git简介

https://git-scm.com/book/zh/v2

Git是目前世界上最流行的分布式版本控制系统,是程序员必须要掌握的工具。

在没有使用版本控制的时候很多人都有过这种经历,如果你正在编写一个程序,经过一段时间的编写你已经积累了很多的文件和代码行,这时候你发现有些代码需要删除或者重构,但是你又担心重构之后的代码出问题,而又无法找回之前的版本,那你只能将目前的代码另存一份,然后每改一次都要另存,久而久之自己也记不清自己要找的代码在哪个版本里面了。随着需求的增加,这时候你需要另外的同学帮忙一块来开发这个程序,你只能将现在的代码发给他,他在你的代码基础上进行开发,最后再手动合并到一块,如果他不小心修改了你的代码,整个代码版本很容易就失控了。

所以我们就需要一个Git可以帮我们自动管理版本的变更,而且可以非常方便地和他人进行协作。


版本库

当我们使用 git init 创建版本库如 task 的时候,在当前目录下会出现一个隐藏的 .git 目录,该目录就是我们版本库的控制目录,我们提交的修改都会记录在这里面,如果把 .git 删除,task 就变成一个普通目录而不是版本库了。


工作区

存放我们代码文件的位置。


暂存区

如同字面意思,就是指暂时存取文件的地方,通过 git add 命令可以将工作区的文件添加到暂存区。暂存区作为一个正式提交至版本库(commit)之前的中转地带,可以让我们临时保存对文件的修改,也可以从暂存区恢复和撤销。


本地仓库

使用 git commit 命令可以将暂存区的文件提交至本地仓库。


远程仓库

我们的作业仓库就是一个远程仓库,它托管在一个中心服务器上,通常我们使用 git clone 命令将远程仓库代码拷贝下来,本地代码更新之后,通过 git push 推送给远程仓库。


文件状态

在仓库目录执行下面的命令可以查看一个文件的状态

git status

我们可能会看到下面几种情况


Changes not staged for commit

工作区中有改内容,但是暂存区没有,我们需要通过 git add 将其添加进暂存区


Changes to be committed

已经被添加进暂存区的文件,可以通过 git commit 提交到版本库,也可以使用 git reset HEAD 来撤销暂存


Untracked files

未追踪的文件,可以通过 git add 添加进暂存区


nothing to commit, working tree clean

工作区所有的更改都已经提交至版本库


分支管理

在我们初始化仓库的时候Git会自动帮我们创建名为 master 的主干分支,在平时的开发中我们通常会创建不同的分支来用于不同的开发目的,例如 master 通常作为主干分支,用于部署生产环境的代码,一般由 develop 分支代码合并而来,任何情况下都不应该直接修改代码。develop 分支作为日常的开发分支,功能开发完毕之后,代码合并进 masterbugfix 分支用来修复 master 的bug,修复完成之后代码需要合并进 masterdevelop

实际情况中比这个一般还要复杂一些,可能还会有一些其他作用的分支。为什么需要这样设计呢?试想一下这样一个场景,大家都在一个主干分支 master 上面开发并且代码已经上线一个版本,然后继续在 master 上面开发新的功能,这时候突然发现了严重的bug需要紧急修复,但是 master 上面的新功能还只开发了一半无法发布版本,只能去修改历史版本的代码,维护比较麻烦。如果我们通过分支的方式来管理就会是下面的步骤了:


  • 首先在 develop 分支开发,等到第一个把版本完成之后,合并进 master,从 master 发布版本
  • develop 分支继续开发新功能
  • master 发现bug需要修复
  • 基于 master 创建 bugfix 分支用于修复bug,bug修复完成合并进 masterdevelop,master 发布新版本上线
  • develop 开发完新功能,继续合并进 master

查看分支

git branch

创建新分支

git branch develop

切换分支

git checkout develop

删除分支

git branch -d develop

删除之前需要先切换到其他分支


删除远程分支

git push -d develop

.gitignore

.gitignore 是Git的忽略文件,用来告诉Git忽略哪些文件,不要将他们加入到追踪列表,.gitignore 会对当前目录及子目录起作用,也可以在不同的目录分别放置,配置示例如下

# 忽略 node_modules/ 目录下所有的文件node_modules# 忽略 dist/ 目录下的所有文件dist# 忽略src下所有的txt文件,包含子目录src/**/*.txt# 忽略src下面的txt,不包含子目录src/*.txt# 忽略所有的md文件.md# 不忽略README.md!README.md

基本操作

我们来看一个基本的Git使用流程


  • 创建本地仓库 test,在空目录 test 执行命令,注意该命令是用来创建版本库,只需要执行一次,也不要在子目录重复执行

git init

  • 设置用户名和邮箱

git config user.name "your_name"git config user.email "your_email"

  • 创建 develop 分支

git branch develop

  • 切换到 develop 分支

git checkout develop

  • 添加文件 index.html

git add index.html

  • 如果我们工作区的文件改错了想要从暂存区恢复,可以执行命令

git checkout index.html

  • 如果我们错误地添加了文件或改动到暂存区,可以执行命令撤销

git reset HEAD index.html

这里的HEAD就是指向当前分支的一个指针


  • 提交暂存区的文件到版本库

git commit -m "message"

  • 查看提交历史

git log

如果要查看最近的两条详情

git log -p -2

  • 合并 develop 分支到 master

git checkout mastergit merge develop

  • 如果我们想要把仓库推到远程服务器,需要先创建好远程仓库地址,然后将本地仓库和远程仓库链接起来,如

git remote add origin https://git.xxx.com/repo/test

这里的origin是我们习惯的远程仓库的别名,你也可以选择其他的名字或者链接到多个不同的远端仓库地址,但是对于同一个远端地址不要重复添加。


  • 推动本地仓库到远端仓库

git push -u origin master

这里的origin是我们前面添加的远端仓库地址的别名,master是分支名称,表示把本地的 master 推送至origin的 master 分支,-u 参数可以让我们以后省略后面的参数,可以直接执行

git push

git push会验证用户的身份


  • 如果别人想要通过远端仓库地址下载这个代码库,可以执行命令

git clone https://git.xxx.com/repo/test

这个命令会自动克隆代码到当前目录的 test 目录,如果你想指定一个其他的名字,可以使用

git clone https://git.xxx.com/repo/test test2

  • 如果想要获取最新的远端仓库代码,可以执行

git pull

如果要取远端仓库的指定分支

git pull origin develop

推荐阅读
  • 本文深入探讨了 Git 与 SVN 的高效使用技巧,旨在帮助开发者轻松应对版本控制中的各种挑战。通过详细解析两种工具的核心功能与最佳实践,读者将能够更好地掌握版本管理的精髓,提高开发效率。 ... [详细]
  • 本文详细介绍了如何安全地手动卸载Exchange Server 2003,以确保系统的稳定性和数据的完整性。根据微软官方支持文档(https://support.microsoft.com/kb833396/zh-cn),在进行卸载操作前,需要特别注意备份重要数据,并遵循一系列严格的步骤,以避免对现有网络环境造成不利影响。此外,文章还提供了详细的故障排除指南,帮助管理员在遇到问题时能够迅速解决,确保整个卸载过程顺利进行。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • Linux CentOS 7 安装PostgreSQL 9.5.17 (源码编译)
    近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x ... [详细]
  • Python 实战:异步爬虫(协程技术)与分布式爬虫(多进程应用)深入解析
    本文将深入探讨 Python 异步爬虫和分布式爬虫的技术细节,重点介绍协程技术和多进程应用在爬虫开发中的实际应用。通过对比多进程和协程的工作原理,帮助读者理解两者在性能和资源利用上的差异,从而在实际项目中做出更合适的选择。文章还将结合具体案例,展示如何高效地实现异步和分布式爬虫,以提升数据抓取的效率和稳定性。 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 大家好,我是李白。本文将分享一个从零开始的全栈项目,涵盖了设计、前端、后端和服务端的全面学习过程。通过这个项目,我希望能够帮助初学者更好地理解和掌握全栈开发的技术栈。 ... [详细]
  • 原文网址:https:www.cnblogs.comysoceanp7476379.html目录1、AOP什么?2、需求3、解决办法1:使用静态代理4 ... [详细]
  • 本文详细介绍了如何使用Python中的smtplib库来发送带有附件的邮件,并提供了完整的代码示例。作者:多测师_王sir,时间:2020年5月20日 17:24,微信:15367499889,公司:上海多测师信息有限公司。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 大类|电阻器_使用Requests、Etree、BeautifulSoup、Pandas和Path库进行数据抓取与处理 | 将指定区域内容保存为HTML和Excel格式
    大类|电阻器_使用Requests、Etree、BeautifulSoup、Pandas和Path库进行数据抓取与处理 | 将指定区域内容保存为HTML和Excel格式 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • Android中将独立SO库封装进JAR包并实现SO库的加载与调用
    在Android开发中,将独立的SO库封装进JAR包并实现其加载与调用是一个常见的需求。本文详细介绍了如何将SO库嵌入到JAR包中,并确保在外部应用调用该JAR包时能够正确加载和使用这些SO库。通过这种方式,开发者可以更方便地管理和分发包含原生代码的库文件,提高开发效率和代码复用性。文章还探讨了常见的问题及其解决方案,帮助开发者避免在实际应用中遇到的坑。 ... [详细]
  • 在JavaWeb项目架构中,NFS(网络文件系统)的实现与优化是关键环节。NFS允许不同主机系统通过局域网共享文件和目录,提高资源利用率和数据访问效率。本文详细探讨了NFS在JavaWeb项目中的应用,包括配置、性能优化及常见问题的解决方案,旨在为开发者提供实用的技术参考。 ... [详细]
author-avatar
他给我留下的美好_813
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有