当前位置: 首页 > news >正文

从0到1学会Git(第三部分):Git的远程仓库链接与操作

写在前面:前面两篇文章我们已经学会了git如何在本地进行使用,这篇文章将讲解如何将本地的git仓库和云端的远程仓库链接起来并使用

为什么要使用远程仓库:因为我们需要拷贝我们的代码给别人以及进行协同开发,就需要有一个云端仓库进行代码的存储和同步,所以我们使用远程仓库来完成该目标。

1.常用的托管服务(远程仓库)

1.1 GitHub(开源):属于国外网站,容易上不去
1.2 GitLab:自己搭建,属于公司使用较为常用的
1.3 Gitee:码云,国内第三方提供,使用较多(也是本篇文章所使用的远程云端仓库)

2.使用码云

完成正常网站都需要的注册登录后,我们需要的是创建一个我们自己的仓库

2.1 创建一个云端仓库

在我们个人主页的右上角选择新建一个仓库
在这里插入图片描述
输入仓库的名称和仓库的介绍,点击创建仓库

在这里插入图片描述
然后下面这三个选项,我们全部不选,保持默认即可,因为我们的本地仓库已经实现了配置

在这里插入图片描述
可以看到我们的仓库已经建立完成了
在这里插入图片描述

2.2生成ssh公钥

首先进入我们本地的仓库,打开git bash。使用下列指令来获得我们本地的SSH公钥

ssh-keygen -t rsa

输入上述指令然后一路回车即可。
效果展示:
我们进入到我们的本地仓库中来,然后执行该命令
在这里插入图片描述
然后我们执行完命令后,问yes或者no或者让你按enter,通通可以不用管,按回车一直往下就可以了。
在这里插入图片描述
执行下列命令获得我们的公钥:

cat ~/.ssh/id_rsa.pub

获得我们的公钥,然后将其复制下来。
在这里插入图片描述

2.3将本地仓库和码云账户进行关联

进入我们码云的设置
在这里插入图片描述
我们在这里面选择SSH公钥:
在这里插入图片描述
将我们生成的公钥放到这里面来,他会自己生成一个标题,我们可以选择重新设置一个,这个不会产生什么影响

在这里插入图片描述
点击保存实现对公钥的配对。
在这里插入图片描述
在我们的本地仓库中输入以下指令,可以知道我们的配置是否成功

ssh -T git@gitee.com

在这里插入图片描述
然后因为你是第一次访问这个网址,他会对你进行询问,我们选择输入yes,然后看到下面弹出来的successfully即可知道我们已经完成了ssh协议的配对.

3.将本地仓库和远程仓库进行添加和配送操作(附带链接操作):

使用下列命令完成本地仓库和云端远程仓库配对的功能。

git remote add origin SSH地址(这里是你云端仓库ssh协议copy的地址)

我们进入自己的仓库,然后选择SSH协议,将其中的SSH地址给复制下来
在这里插入图片描述
然后我们使用上述命令:告诉本地仓库,远程仓库是什么,其中origin是名称的意思,指的是你想连接的远程仓库你想把它叫做什么,我们直接取默认的origin即可,不需要进行改变 。
如果出现以下问题:
在这里插入图片描述
表明我们在git bash执行的文件夹不是一个本地仓库文件,如果要将该文件夹和云端仓库进行链接,需要先执行一下git init将该文件夹生成为一个本地仓库即可。
如果输入完连接指令,没有任何的提醒,即实现了连接。
如何将我们本地的代码提交上去

git push origin master

把master分支提交到了origin仓库里:
在这里插入图片描述
第一次提交的时候会出现提示这种情况,出现这样表示我们的本地仓库已经提交成功了。
完整的指令为:

git push [-f][--set-upstream][远端名称[本地分支名][:远端分支名]]

-f表示的是强制覆盖,即本地代码强行覆盖云端代码
–set-upstream 表示推送到远端的同时并且建立起和远端分支的关联关系
如果当前分支已经和远端分支关联,可以省略分支名和远端名
直接

git push

将master分支推送到已关联的远端分支
在这里插入图片描述
此时表明的是我们没有将两个分支进行捆绑起来,所以我们先使用

git push --set-upstream origin master:master

然后再次使用git push即可
我们使用git branch -vv即可查看到我们各个分支的关系

4.从远程仓库克隆

git clone <仓库路径>[本地目录]

我们使用一个全新的文件夹来实现这个操作
在这里插入图片描述
我们新建一个test2文件夹来进行此操作,将此链接复制下来
在这里插入图片描述
然后输入

git clone 链接

或者git clone <仓库路径>[本地目录]
则会直接在当前目录下克隆下来一个仓库
在这里插入图片描述
进去即可得到我们克隆下来的本地仓库
可以看到只有master分支,没有dev分支,因为我们的远程仓库只存了master分支而没有存dev分支
在这里插入图片描述

5.从远程仓库中抓取和拉取

抓取和拉取的区别:抓取是把云端代码拉下来,然后需要人为进行合并。拉取是把云端代码拉下来,直接进行合并。
抓取:将仓库里的更新抓取到本地,不会进行合并
remote name就是origin

git fetch [remote name][branch name]

拉取:将远端仓库的修改拉取到本地并自动进行合并,等同于fetch+merge

git pull [remote name][branch name]

上传操作(位于test1文件夹下,我们首先往云端里面新建增加一个文件,以达到在test2文件夹下面的文件和云端仓库文件不一样的效果):
在这里插入图片描述
在这里执行了git push之后可以看到master分支和origin里面的master分支实现了同步的功能。
在这里插入图片描述
拉取操作(test2文件夹下):
在这里插入图片描述
现在在test2下面是没有file04.txt文件的,然后我们将其拉取下来
在这里插入图片描述
在这里插入图片描述
可以看到已经有了file04,但是master里面没有file04文件
在这里插入图片描述
在这里插入图片描述
然后我们把远程的分支合并过来,可以看到文件夹下已经有了file04
在这里插入图片描述
抓取操作(test2文件夹下,因为已经实现了文件的一致,所以题主偷懒,就直接不放图片了):

git pull 

实现效果:git pull ==git fetch + git merge

6.远程冲突问题解决

用户a和b同时对文件c的第1行进行了更改,然后a进行了提交到云端仓库,b在进行提交的时候就会提醒出现问题。因为两行代码不同,会出现冲突问题。
解决方案:当b提交时出现报错后,先执行git pull,然后对代码进行修改,在执行git push即可。

7.有关git push和git pull的一点理解(主观性较强,可以不看)

解决冲突问题的核心其实就是会出现不一致的问题,所以建议在进行更改代码的时候(即不知道有没有人对有关代码进行更改),先执行git pull操作,再执行git push操作,就不会出现报错问题。题主是这么理解的,远程仓库会检测是谁执行了最后一次的git push操作(以仓库为单位,其实也就是以文件夹为单位),如果检测到是此本地仓库执行的,则执行git push操作会直接成功,相当于它意识到除了此本地仓库以外没有人更改了代码,只有你这个本地仓库在改代码,所以他会直接的默认覆盖or删除or修改操作。如果检测不是此本地仓库执行了最后一次的git push操作,则他会默认你没有拿到最新的云端仓库,已经有人对里面的代码进行了更改,所以你提交的git push操作里面,可能把上一个人的操作给覆盖了,即上一个人的操作你没有看到,可能会出现无意识的覆盖,此操作很危险,会出现问题,所以会报错。需要你git pull下来后,看到最新的代码,在执行git push才可。这也就是很多人说的,先pull在push的原因。
为了更好的理解这个问题,题主做了以下测试来进行验证:
首先我们新添加一个本地仓库test3,然后把云端仓库(也就是和test1保持一致的那个文件央视)克隆下来。

请添加图片描述
然后我们对文件的内容进行修改:
请添加图片描述
进行git push上去,发现没有问题(因为发现它git pull拉取下来后,没有人再进行新的push,即获得到了最新的版本文件,所以可以直接进行提交),所以直接push上去没有任何问题
请添加图片描述
我们在回到我们的test1文件夹(即最开始和云端仓库保持一致的文件夹):

可以发现里面的内容还是之前修改之前的内容,所以此时没有和云端仓库的内容保持一致。
在这里插入图片描述

我们修改他的内容。
请添加图片描述

然后提交到本地仓库。

请添加图片描述
然后在push到云端仓库的时候发生了报错,因为他检测到有别的本地仓库对里面的数据进行了更改,然后test1仓库没有进行pull操作,即没有拿到最新的仓库,所以会报错。
请添加图片描述
我们进行拉取操作
请添加图片描述
可以看到里面因为冲突,已经变成和本地仓库一样的问题了(即冲突之后,会将文件合并在工作区而不是本地仓库里,如果觉得有点饶,可以去看题主的git的第二部分的文章)
请添加图片描述
然后我们啥都不做,继续push,可以发现,仍然不行,因为我们的冲突问题依然存在,而解决后的问题的文件在工作区中,而不在本地仓库里面。
请添加图片描述
我们先将文件放到本地仓库中,然后执行git push操作,可以看到,已经成功的将文件上传了。

请添加图片描述
我们再将test1仓库下面的文件进行修改。
请添加图片描述

然后在不pull的情况下,将其再次提交上去,发现我们已经可以直接push了,因为检测到上一次git push的仓库就是test1,它默认test1用的就是最新的仓库,所以再次使用push操作不需要先拉取。
请添加图片描述
总结:如果对云端仓库的最后一次push操作是此仓库干的,则此仓库下次push不需要先进行pull操作。如果最后一次操作不是本仓库干的,则需要进行pull操作,且pull完成后需要先把文件放到本地仓库(因为可能会出现本地仓库冲突问题),为了保险起见,可以每次pull完,对数据处理完毕,进行一波add操作和commit操作,再进行push操作即可。(附:如果最后一次push操作是此仓库所操作的,则下次执行git pull不会有任何作用,因为云端仓库会认为,您已经有了最新的仓库,而您后续的操作是您想干的,他不会帮您更改文件内容or修复删除的文件?)

写在最后:码字不易,点个赞再走把

相关文章:

从0到1学会Git(第三部分):Git的远程仓库链接与操作

写在前面:前面两篇文章我们已经学会了git如何在本地进行使用&#xff0c;这篇文章将讲解如何将本地的git仓库和云端的远程仓库链接起来并使用 为什么要使用远程仓库:因为我们需要拷贝我们的代码给别人以及进行协同开发&#xff0c;就需要有一个云端仓库进行代码的存储和同步&a…...

虚拟机Ubuntu操作系统常用终端命令(1)(详细解释+详细演示)

虚拟机Ubuntu操作系统常用终端命令 本篇讲述了Ubuntu操作系统常用的三个功能&#xff0c;即归档&#xff0c;软链接和用户管理方面的相关知识。希望能够得到大家的支持。 文章目录 虚拟机Ubuntu操作系统常用终端命令二、使用步骤1.归档1.1创建档案包1.2还原档案包1.3归档并压缩…...

redis实战-redis实现异步秒杀优化

秒杀优化-异步秒杀思路 未优化的思路 当用户发起请求&#xff0c;此时会请求nginx&#xff0c;nginx会访问到tomcat&#xff0c;而tomcat中的程序&#xff0c;会进行串行操作&#xff0c;分成如下几个步骤 1、查询优惠卷 2、判断秒杀库存是否足够 3、查询订单 4、校验是否是一…...

Python爬虫-IP隐藏技术与代理爬取

前言 在进行爬虫程序开发和运行时&#xff0c;常常会遇到目标网站的反爬虫机制&#xff0c;最常见的就是IP封禁&#xff0c;这时需要使用IP隐藏技术和代理爬取。 一、IP隐藏技术 IP隐藏技术&#xff0c;即伪装IP地址&#xff0c;使得爬虫请求的IP地址不被目标网站识别为爬虫。…...

二刷力扣--链表

链表 链表类型&#xff1a; 单链表&#xff08;可以访问后面的一个节点&#xff09; 双链表&#xff08;可以访问前后节点&#xff09; 循环链表&#xff08;最后一个节点指向首节点&#xff09; 在Python中定义单链表节点&#xff1a; class ListNode:def __init__(self, v…...

返回值加const ,为了不拷贝得到成员的值,但被赋值的左值也要const

1. getA 函数返回值 什么都不加&#xff0c;也改不了c里面a的指针指向 why&#xff1f;返回成员变量时&#xff0c;会复制一下。 返回成员变量时&#xff0c;一般会赋值一下没有RVO_地摊书贩的博客-CSDN博客 2. getA 函数返回值 加了引用&#xff0c; 就没有复制 3. getA 函数…...

本地如何使用HTTPS进行调试

在现代前端开发中&#xff0c;HTTPS已经成为不可或缺的一部分&#xff0c;因为它在保护用户数据和确保网站安全性方面发挥着关键作用。然而&#xff0c;有时在本地开发过程中启用HTTPS可能会变得有些复杂。在本文中&#xff0c;我们将介绍如何轻松地在本地进行HTTPS调试&#x…...

观察者模式:对象之间的订阅机制

欢迎来到设计模式系列的第十三篇文章&#xff01;在之前的文章中&#xff0c;我们学习了许多常用的设计模式&#xff0c;今天我们将介绍观察者模式&#xff0c;它是一种行为型设计模式&#xff0c;用于定义对象之间的一对多依赖关系&#xff0c;当一个对象的状态发生变化时&…...

【1462. 课程表 IV】

来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 描述&#xff1a; 你总共需要上 numCourses 门课&#xff0c;课程编号依次为 0 到 numCourses-1 。你会得到一个数组 prerequisite &#xff0c;其中 prerequisites[i] [ai, bi] 表示如果你想选 bi 课程&#xff0c;你…...

Kerberos 身份验证

简介 Kerberos 是一种由 MIT&#xff08;麻省理工大学&#xff09;提出的一种基于加密 Ticket 的身份认证协议。它旨在通过使用密钥加密技术为客户端/服务器应用程序提供强身份验证&#xff0c;用于验证用户或主机的标识。。 适用范围&#xff1a;Windows Server 2022、Window…...

R语言贝叶斯METROPOLIS-HASTINGS GIBBS 吉布斯采样器估计变点指数分布分析泊松过程车站等待时间...

原文链接&#xff1a;http://tecdat.cn/?p26578 指数分布是泊松过程中事件之间时间的概率分布&#xff0c;因此它用于预测到下一个事件的等待时间&#xff0c;例如&#xff0c;您需要在公共汽车站等待的时间&#xff0c;直到下一班车到了&#xff08;点击文末“阅读原文”获取…...

通付盾入选2023年度“上市苗圃工程”重点企业

近日&#xff0c;2023年度苏州工业园区企业上市苗圃工程认定名单公示&#xff0c;江苏通付盾科技有限公司成功入选园区“上市苗圃工程”重点企业。 2023年第一批次苗圃企业认定结果&#xff1a; 企业上市苗圃工程 上市企业是衡量地方综合经济实力的重要标尺&#xff0c;也是区…...

SpringMVC之文件上传下载

SpringMVC是一个基于Java的Web框架&#xff0c;它提供了一套用于构建Web应用程序的开发模型。在SpringMVC中&#xff0c;文件上传和下载是常见的功能之一。 SpringMVC文件上传和下载的介绍&#xff1a; 介绍文件上传&#xff1a; 在SpringMVC中&#xff0c;文件上传功能可以通…...

嵌入式IDE(2):KEIL中SCF分散加载链接文件详解和实例分析

在上一篇文章IAR中ICF链接文件详解和实例分析中&#xff0c;我通过I.MX RT1170的SDK中的内存映射关系&#xff0c;分析了IAR中的ICF链接文件的语法。对于MCU编程所使用的IDE来说&#xff0c;IAR和Keil用得比较多&#xff0c;所以这一篇文章就来分析一下Keil的分散文件.scf(scat…...

Linux防火墙常用操作及端口开放

Linux防火墙常用操作及端口开放 1.查看防火墙状态 firewall-cmd --state 2.开启防火墙 systemctl start firewalld.service 3.开启指定端口 firewall-cmd --zonepublic --add-port3306/tcp --permanent firewall-cmd --zonepublic --add-port6379/tcp --permanent 显示success表…...

[JAVAee]Linux上的javax.mail报错

我们把在window写的项目部署到Linux上的Tomcat时,如果发现使用不了了,该如何找到错误呢?找到报错的地方在哪呢? 在Linux环境下来到Tomcat目录下的logs目录,输入: tail -f catalina.out -n 500 tail 就是把文件的末尾几行读取到终端上,并会持续刷新 -f 循环读取 catalina.ou…...

开学季|校园迎新哪家强?VR全景来导航

九月开学迎新季&#xff0c;各大高校的迎新活动开展的如火如荼&#xff0c;随着科技的不断进步&#xff0c;高校为了更好的开展迎新活动&#xff0c;让新生们尽快熟悉新的校园和生活&#xff0c;会利用VR全景技术带领着新生进行校园游览&#xff0c;给予新生们巨大便利的同时&a…...

el-checkbox-group限制勾选数量

<!--* Description: 视频监控 页面* Author: mhf* Date: 2023-08-15 13:26:33 --> <template><div class"videoSurveillance"><el-row :gutter"24"><el-col :span"4"><div class"videoSurveillance-left&…...

【JavaScript】WebAPI入门到实战

文章目录 一、WebAPI背景知识1. 什么是WebAPI&#xff1f;2. 什么是API&#xff1f; 二、DOM基本概念三、获取元素三、事件初识1. 点击事件2. 键盘事件 四、操作元素1. 获取/修改元素内容2. 获取/修改元素属性3. 获取/修改表单元素属性4. 获取/修改样式属性 五、操作节点1. 新增…...

奥康的高尔夫鞋,圈不住投资者的心

文 | 螳螂观察 作者 | 青月 鞋服行业终于熬过了“寒冬”&#xff0c;2023年行业景气度开始逐步回暖。 东方财富Choice数据显示&#xff0c;截至8月17日&#xff0c;已有28家鞋帽服装类上市公司发布了2023年中期业绩预告或快报&#xff0c;其中&#xff0c;9家预增&#xff0…...

vue2配置环境变量并且nginx运行成功

需求&#xff1a;我在vue项目配置了生产环境和开发环境&#xff0c;之后通过proxy代理的方式把地址转发到真实的服务器地址上用于请求接口&#xff0c;之后把项目打包后上传到nginx上&#xff0c;之后接口报错404&#xff0c;但是本地运行是可以访问的&#xff0c;找了很久终于…...

Java+Swing形成GUI图像界面

一、Swing 简介 Swing 主要用来开发 GUI 程序,GUI(Graphical User Interface)即图形用户界面。Java 中针对 GUI 设计提供了丰富的类库,这些类分别位于 java.awt 和 java.swing 中,简称 AWT 和 Swing ;其中,AWT(Abstract Window Toolkit)是抽象窗口工具包,是 Java 平…...

编辑距离 -- 动规

72. 编辑距离 给出动规的两种常见实现形式&#xff1a;自顶向下、自底向上&#xff0c;前者一般借助递归函数备忘录实现&#xff0c;后者通常基于dp数组实现。 class MinDistance:"""72. 编辑距离https://leetcode.cn/problems/edit-distance/""&quo…...

douyin【商品抢购js脚本】

文章目录 前言订阅须知知识点源码前言 脚本主要用来实现抢购douyin商城、直播间秒杀商品等一系列商品 订阅须知 订阅后,只提供js源代码,不提供教学,请根据源码自行抓包知识点 1、在查询串插入一个固定的键rstr   2、对查询串进行按键排序并取值,对空格和+进行转义为a …...

常见Web安全技术总结!474页Web安全从入门到精通(附PDF)

Web安全范围比较大&#xff0c;知识点比较杂&#xff0c;很多朋友都无从下手&#xff0c;这不可怕&#xff0c;可怕的是乱下手&#xff0c;其实往往基础才是决定你是否能走远的关键。 为了帮助大家入门网安&#xff0c;给大家推荐一份《新手Web安全入门到精通》&#xff0c;共…...

Prometheus 监控指南:如何可靠地记录数字时间序列数据

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f405;&#x1f43e;猫头虎建议程序员必备技术栈一览表&#x1f4d6;&#xff1a; &#x1f6e0;️ 全栈技术 Full Stack: &#x1f4da…...

rsync远程同步+inotify监控

目录 一、Rsync 简介 1、rsync是什么 2、备份的方式 3、rsync同步方式 4、常用rsync命令 5、配置源的两种表达方法 二、rsync实验 1、本地复制 ​编辑​编辑 2、异地复制 2.1 rsync服务器配置 2.2 rsync客户端配置 2.2.1 普通同步 2.2.2 免密同步 2.2.3 --delet…...

【面试经典150 | 数组】移除元素

文章目录 写在前面Tag题目来源题目解读解题思路方法一&#xff1a;原地操作 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的数据结构等…...

玩转Mysql系列 - 第21篇:什么是索引?

这是Mysql系列第21篇。 本文开始连续3篇详解mysql索引&#xff1a; 第1篇来说说什么是索引&#xff1f; 第2篇详解Mysql中索引的原理 第3篇结合索引详解关键字explain 本文为索引第一篇&#xff1a;我们来了解一下什么是索引&#xff1f; 路人在搞计算机之前&#xff0c;…...

预处理指令

// The include directive instructs the preprocessor to paste the text of the given file into the current file. // 粘贴指定文件的内容 #include // 定义宏PI #define PI 3.1415926 // 取消定义PI #undef PI条件编译(Conditional Compilation) // 检查xxx是否已被定义为…...

朔州网站建设价格/小程序开发软件

本文转载自&#xff1a;http://www.blogjava.net/BlueDavy/archive/2009/04/28/267970.html&#xff0c; 转载请注明 在这篇blog中放置了我收集的一些网站架构相关的PPT和文章&#xff0c;提供给大家下载&#xff0c;如果大家有相关的好的PPT、文章的话&#xff0c;也欢迎推…...

山东网站建设负面消息处理/郑州抖音seo

浏览器被劫持如何恢复? 参考链接: 关于IE主页被锁定为毒霸网址大全的解决方法 https://www.iefans.net/ie-zhuye-suoding-duba-wangzhi-daquan/ 直接删除被劫持软件的携带软件,如下面几个常用的流氓网站: 1、2345.com2、毒霸网络大全 duba.com 金山毒霸、WPS、驱动精…...

辛集市住房和城乡建设局网站/企业网站注册域名的步骤

企业管理软件现在最大的竞争&#xff0c;我个人感觉是外包公司。 现在外包行当不好做了&#xff0c;所以很自然都纷纷开始在国内市场出击。这些经历了国外客户锤炼和要求的外包公司&#xff0c;在项目管理、文档、测试、质量均有明显优势。而国内客户对于国内的企业管理软件&am…...

wordpress文章调用插件/求职seo服务

简单面试题&#xff0c;但是容易忘记 1.为什么等待和通知是在 Object 类而不是 Thread 中声明的&#xff1f; **1) wait 和 notify 不仅仅是普通方法或同步工具&#xff0c;更重要的是它们是 Java 中两个线程之间的通信机制。**对语言设计者而言, 如果不能通过 Java 关键字(例…...

wordpress首页缓存/seo排名优化代理

在前面关于加密的文章中&#xff0c;讲到使用open62541自带的python脚本create_self-signed.py去生成证书和私匙&#xff0c;该脚本运行需要安装库netifaces pip3 install netifaces在Linux下可以正确安装和使用。但是在Windows上却没那么顺利&#xff0c;该库依赖cl.exe&…...

外贸网站建设560/百度seo免费推广教程

题目描写叙述 给你一个有N个数的集合S和一个数X&#xff0c;推断是否存在S的一个子集&#xff0c;子集里的数的最小公倍数正好是X。 输入 第一行是数据组数T。 接下来有多组数据&#xff0c;每组数据包括两行&#xff1a; 第一行有2个数N和X&#xff0c;1<N<100000 &…...