百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Git实战005:如何正确的使用同步、获取和拉取指令

wptr33 2024-11-06 20:32 17 浏览

为了更好的管理、跟进、掌控和维护项目开发,我们通常会借用Gitlab等代码托管平台来管理项目资源。当然我们不会将项目公开在互联网上,而是在局域网搭建属于自己的Git远程仓库服务(我司搭建的是Gitlab服务)。在使用Git的使用我们经常需要对项目执行同步、获取和拉取等操作,那么我们在实际应用中该如何使用相关指令呢?

克隆资源clone

如果你是刚刚参与项目的开发那么你需要先获取当前已经开发的项目资源,这时候就需要从从远程仓库克隆资源。执行指令: git clone -b <分支名> <版本库的网址>;将指定分支克隆到本地新目录中(不指定分支则默认克隆master分支),执行git clone后会在新目录下有个.git的隐藏文件夹,所以clone下来的项目不需要进行git init初始化操作。

查看分支branch

在Git中分支一般有本地版本库分支和远程版本库分支,在项目目录中查看本地版本库分支可以执行指令:git branch,如果查看远程版本库分支可以执行指令:git branch -r,如果想同时查看本地和远程仓库的分支情况可以执行指令:git branch -al。通常本地分支显示为绿色而远程分支显示为红色,前面带符合“*”表示当前所在的分支。

同步分支

这里我们可以看到远程版本库中还有一个dev分支,而本地版本库目前只有master分支。现在我想把dev分支也取回,这个我们可以通过指令:git checkout -b <本地分支名> <origin/远程分支名>将远程仓库里的指定分支拉取到本地,并同时在本地新建了一个和指定远程分支关联的dev分支。该指令在本地仓库新建分支并自动切换到该分支,并自动建立的本地分支会和远程分支的映射关系。将本地所有分支与远程版本库保持同步 git fetch --all,拉取远程版本库所有分支 git pull --all。

?获取状态fetch

当用户向远程仓库提交更新之后我们需要去获取当前项目的最新资源,这时候我们需要知道当前资源做了哪些更新。通过指令:git fetch <远程主机名> <分支名>可以将远程版本库的特定分支更新取回,如果不指定分支则将远程主机的更新全部取回本地本地版本库。取回更新后会返回一个FETCH_HEAD 指针指向branch在服务器上的最新状态,我们可以在本地通过指令:git log -p FETCH_HEAD查看当前指针所在分支取回的更新信息。返回的信息包括更新的文件名、更新的作者和时间以及更新的内容,我们可以通过这些信息来判断是否产生冲突以确定是否将更新merge到当前分支。

?合并分支merge

fetch只是将当前项目分支在远程仓库上的最新状态取回,此时只是将状态存在了本地暂存库中并没有与本地分支进行合并,所以在本地并没有还看不到远程仓库上更新的内容。fetch可以帮助我们查看更新的内容是否与已有资源产生冲突,这样我们就可以选择分支更新进行合并。合并分支可以通过指令:git merge <远程主机名> /<分支名>将指定分支上拉取下来的最新内容合并到当前所在的分支中,如果不放心可以通过指令:git diff <分支名>来比较本地代码与刚刚从远程下载下来的代码的区别。

?拉取分支pull

如果你不需要检查远程仓库的具体更新信息时我们可以直接使用指令:git pull <远程主机名> <远程分支名>:<本地分支名>取回远程仓库指定分支的更新并与本地分支合并,如果不指定本地分支则默认拉取到本地的当前分支进行合并。git pull相当于执行git fetch后并调用git merge将检索到的分支头合并到分支中,相比起来git fetch更安全一些,虽然麻烦些(需要手动合并)但是可以在merge前查看更新情况然后再决定是否合并。

?总结

同步顾名思义就是保持本地版本库与远程版本库的信息一致,当本地有新分支而远程仓库没有、远程仓库有新分支而本地没有、本地删除了分支时远程也需要删除、远程删除了分支时本地也同时删除时就可以用同步来解决。其他的局部资源更新则可以根据实际情况来拉取,如果需要对更新进行查阅那么就先进行获取然后再手动合并分支即可。

相关推荐

【推荐】一款开源免费、美观实用的后台管理系统模版

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍...

Android架构组件-App架构指南,你还不收藏嘛

本指南适用于那些已经拥有开发Android应用基础知识的开发人员,现在想了解能够开发出更加健壮、优质的应用程序架构。首先需要说明的是:AndroidArchitectureComponents翻...

高德地图经纬度坐标批量拾取(高德地图批量查询经纬度)

使用方法在桌面上新建一个index.txt文件,把下面的代码复制进去保存,再把文件名改成index.html保存,双击运行打开即可...

flutter系列之:UI layout简介(flutter ui设计)

简介对于一个前端框架来说,除了各个组件之外,最重要的就是将这些组件进行连接的布局了。布局的英文名叫做layout,就是用来描述如何将组件进行摆放的一个约束。...

Android开发基础入门(一):UI与基础控件

Android基础入门前言:...

iOS的布局体系-流式布局MyFlowLayout

iOS布局体系的概览在我的CSDN博客中的几篇文章分别介绍MyLayout布局体系中的视图从一个方向依次排列的线性布局(MyLinearLayout)、视图层叠且停靠于父布局视图某个位置的框架布局(M...

TDesign企业级开源设计系统越发成熟稳定,支持 Vue3 / 小程序

TDesing发展越来越好了,出了好几套组件库,很成熟稳定了,新项目完全可以考虑使用。...

WinForm实现窗体自适应缩放(winform窗口缩放)

众所周知,...

winform项目——仿QQ即时通讯程序03:搭建登录界面

上两篇文章已经对CIM仿QQ即时通讯项目进行了需求分析和数据库设计。winform项目——仿QQ即时通讯程序01:原理及项目分析...

App自动化测试|原生app元素定位方法

元素定位方法介绍及应用Appium方法定位原生app元素...

61.C# TableLayoutPanel控件(c# tabcontrol)

摘要TableLayoutPanel在网格中排列内容,提供类似于HTML元素的功能。TableLayoutPanel控件允许你将控件放在网格布局中,而无需精确指定每个控件的位置。其单元格...

想要深入学习Android性能优化?看完这篇直接让你一步到位

...

12个python数据处理常用内置函数(python 的内置函数)

在python数据分析中,经常需要对字符串进行各种处理,例如拼接字符串、检索字符串等。下面我将对python中常用的内置字符串操作函数进行介绍。1.计算字符串的长度-len()函数str1='我爱py...

如何用Python程序将几十个PDF文件合并成一个PDF?其实只要这四步

假定你有一个很无聊的任务,需要将几十个PDF文件合并成一个PDF文件。每一个文件都有一个封面作为第一页,但你不希望合并后的文件中重复出现这些封面。即使有许多免费的程序可以合并PDF,很多也只是简单的将...

Python入门知识点总结,Python三大数据类型、数据结构、控制流

Python基础的重要性不言而喻,是每一个入门Python学习者所必备的知识点,作为Python入门,这部分知识点显得很庞杂,内容分支很多,大部分同学在刚刚学习时一头雾水。...