git远程操作,推送【push】,拉取【pull】,忽略特殊文件,配置别名,标签管理

news/2024/10/18 7:50:53/

文章目录

    • 前言:
      • 新建远程仓库克隆
      • 推送【push】
      • 拉取【pull】
    • 配置git
      • 忽略特殊文件
      • 给命令配置别名
    • 标签管理
      • 理解标签
      • 创建标签
      • 操作标签

前言:

大家如果没有看过前几章git的基础操作的话,推荐先看一下,看完再来看这个远程操作,这样会对git有一个深的理解~~

  • GIT | 基础操作 | 初始化 | 添加文件 | 修改文件 | 版本回退 | 撤销修改 | 删除文件

  • git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支

接下来我们对本章的正题:

Git是一款分布式版本控制系统,它允许团队协同开发并追踪代码变更。远程操作是Git中的一个重要概念,它使得开发者能够在不同计算机之间共享和同步代码。这里也不多介绍,可以到百度上面自行寻找~~

本教程使用的是码云(gitee.com)来演示

新建远程仓库克隆

  • 首先就是要先注册一个自己的账号
  • 然后新建仓库

在这里插入图片描述

在这里插入图片描述

  • 这里有两种方法来clone仓库到本地,一个是https一个是ssh

  • 我们不使用https,原因是https比较简单

    • 首先就是配置用户名和邮箱然后(这里配置命令在初始git操作就讲述了)然后直接使用这个命令git clone 复制的仓库链接
  • 接下来我们就使用这个ssh来配置一下

    • 使用ssh方式克隆仓库,由于我们没有添加公钥到远端库中,所以会克隆失败,这里就不演示了,接下来我们就开始配置一下如何将公钥添加
  • 首先打开设置->ssh公钥->公钥

  • 那么这里的公钥在哪里获取呢,当然是在自己的电脑或者远端服务器上获取~~

在这里插入图片描述

  • 我这里就在自己电脑上演示了,远端服务器获取也是一样的~~
  • 输入一下命令,注意: 这里改成自己的邮箱~~
ssh-keygen -t ed25519 -C "shilinnull@163.com"

在这里插入图片描述

  • 然后会在上图的地址会显示地址,找到这个文件夹就可以了,其中第二个带有.pub的后缀是公钥,我们用记事本打开复制里面的内容

在这里插入图片描述

  • 然后粘贴到刚刚的那个网站的公钥栏里就可以了,标题随便写就可

在这里插入图片描述

  • 最后再使用ssh的方式克隆

在这里插入图片描述

  • OK,可以看到已经成功了~~

在这里插入图片描述

推送【push】

  • 我们对仓库里的文件进行修改

在这里插入图片描述

  • 然后进行添加

在这里插入图片描述

  • 最后一个关键的步骤,就是push
git push origin master

在这里插入图片描述

  • 然查看远端仓库,可以看到已经被修改了

在这里插入图片描述

拉取【pull】

  • 我们首先对远端仓库直接进行了修改

在这里插入图片描述

  • 而我们这次又对本地又进行了修改,然后再添加

在这里插入图片描述

  • 最后进行提交操作,发现是无法提交的,会有冲突

在这里插入图片描述

  • 这个时候就需要我们首先对远端仓库进行拉取
git pull origin master

在这里插入图片描述

在这里插入图片描述

  • 这里又回到冲突那里了,然后我们需要进行手动修改一下然后再进行提交

在这里插入图片描述

  • 然后再进行添加提交操作

在这里插入图片描述

  • 可以看到也已经是有了~~

在这里插入图片描述

配置git

忽略特殊文件

  • 在日常开发中,我们有些文件不想提交到远程仓库,那么怎么做呢?

    • 这个时候我们就需要在自己仓库的根目录下建立一个特殊的文件.gitignore,把需要忽略的文件名填进去,git提交的时候就会自动忽略这些文件了~~
  • 我们来演示一下

  • 这里的*代表是通配符,也就是将后缀.txt的文件都忽略

在这里插入图片描述

  • 我们查看一下git的状态,可以看到是没有文本.txt在这里插入图片描述

  • 再次添加后提交

在这里插入图片描述

  • 来到我们的远程仓库查验证一下

在这里插入图片描述

  • 但有些时候,你就是想添加⼀个文件到 Git,但由于这个文件被 .gitignore 忽略了,根本添加不了,那么可以⽤ -f 强制添加:
git add -f [filename]
  • 或者你发现,可能是 .gitignore 写得有问题,需要找出来到底哪个规则写错了,比如说 a.so 文件
    是要被添加的,可以用 git check-ignore 命令检查:
git check-ignore -v file.txt
  • Git 会告诉我们, .gitignore 的第几行规则忽略了该⽂件,于是我们就可以知道应该修订哪个规则。

还有些时候,当我们编写了规则排除了部分文件时,例如:

# 排除所有.开头的隐藏⽂件:
.*
  • 但是我们发现 .* 这个规则把 .gitignore 也排除了。虽然可以⽤ git add -f 强制添加进去,但有强迫症的同学还是希望不要破坏 .gitignore 规则,这个时候,可以添加⼀条例外规则:
# 排除所有.开头的隐藏⽂件:
.*# 不排除.gitignore
!.gitignore
  • 把指定文件排除在 .gitignore 规则外的写法就是 ! +文件名,所以,只需把例外文件添加进去即可

给命令配置别名

  • 在使用git的时候,我们有的时候使用命令太长太麻烦了,我们可以将git命令进行重命名成一个简短的,我们这样操作:

  • 比如我们将git status简写成git st

  • 这里的alias.改成自己想要改成的名字

git config --global alias.st status
  • --global参数是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有⽤。如果不加,那只针对当前的仓库起作用

  • 这样就可以进行重命名成功了,原来的名字也是可以用的~~

在这里插入图片描述

标签管理

理解标签

  • 这个标签,我们可以简单理解是对某一次的commit的一个标识,也就是相当于起了一个别名
  • 对于难以记住的commit id,tag就可以很好的解决这个问题,标签就可以定位到某一个重要的版本,使用标签就可以快速定位到那个版本,这样就很方便快捷

创建标签

  • 首先查看一下在哪个分支上,如果需要打标签到哪个分支上就要切换到哪个分支上
git branch

在这里插入图片描述

  • 然后就可以打标签了 tag后面跟上标签名字就可以
git tag v1.0
  • 打完标签肯定是要查看一下
git tag

在这里插入图片描述

  • 这个标签是没有指定打到哪个commit id上的,所以就是默认,默认就是打在最新提交的commmit上的

  • 那么我们要在指定commit id上打标签,我们可以在后面跟上commit id

git tag v0.9 741df88

在这里插入图片描述

注意: 这里的标签可不算按照时间列出的,是按照字母进行排序的

  • 我们还可以查看标签信息:show后面跟上标签名字,就可以查看具体信息了
git show v1.0

在这里插入图片描述

  • 我们这里还可以指定带有说明的标签,-a指定别名,-m指定说明文字
git tag -a [name] -m "XXX" [commit_id]

在这里插入图片描述

操作标签

  • 如果标签打错了,我们还可以删除 -d后面跟上标签名字
git -d v0.8

在这里插入图片描述

  • 因为创建的标签都只存储在本地,不会⾃动推送到远程。所以,打错的标签可以在本地安全删除

  • 如果要推送某个标签到远程,可以使用命令

git push origin <tagname>

在这里插入图片描述

  • 我们查看远程仓库,可以看到已经推送成功了
    在这里插入图片描述

  • 如果本地仓库有很多标签,可以一次性全部推送到远端

git push oringe --tags

在这里插入图片描述

  • 也是相当的完美已经推送上去了
    在这里插入图片描述

  • 如果要进行删除标签,就要先从本地仓库里删除,然后再推送一次,进行更新

  • 冒号后面跟上标签的名字即可~~

git push origin :v0.9

在这里插入图片描述

  • 我们再次来远端仓库
  • 已经完美删除了~~

在这里插入图片描述

好了,git的远程操作到这里就结束了,希望大家都可以掌握这些技能,这是对能力的一大提升,也希望大家努力学习!加油!


http://www.ppmy.cn/news/1283196.html

相关文章

声明 | 为打击假冒账号、恶意抄袭账号等诈骗活动,提升本账号权威,本博主特此郑重声明

声明 | 为打击假冒账号、恶意抄袭账号诈骗活动&#xff0c;提升本账号权威&#xff0c;本博主特此郑重声明 一、本账号为《机器学习之心》博主CSDN唯一官方账号&#xff0c;唯一联系方式见文章底部。 二、《机器学习之心》博主未授权任何第三方账号进行模型合作、程序设计、源…

【数据库系统概论】第3章-关系数据库标准语言SQL(3)

文章目录 3.5 数据更新3.5.1 插入数据3.5.2 修改数据3.5.3 删除数据 3.6 空值的处理3.7 视图3.7.1 建立视图3.7.2 查询视图3.7.3 更新视图3.7.4 视图的作用 3.5 数据更新 3.5.1 插入数据 注意&#xff1a;插入数据时要满足表或者列的约束条件&#xff0c;否则插入失败&#x…

安全运维是做什么的,主要工作内容是什么

安全运维&#xff0c;简称SecOps&#xff0c;是一种集成安全措施和流程到信息技术运维的实践。它的目的是确保在日常运维活动中&#xff0c;如网络管理、系统维护、软件更新等&#xff0c;均考虑并融入安全策略。安全运维的核心是实现安全和运维团队的密切协作&#xff0c;以快…

【并发设计模式】聊聊 基于Copy-on-Write模式下的CopyOnWriteArrayList

在并发编程领域&#xff0c;其实除了使用上一篇中的属性不可变。还有一种方式那就是针对读多写少的场景下。我们可以读不加锁&#xff0c;只针对于写操作进行加锁。本质上就是读写复制。读的直接读取&#xff0c;写的使用写一份数据的拷贝数据&#xff0c;然后进行写入。在将新…

Dash中的callback的使用 多input 6

代码说明 import plotly.express as pxmport plotly.express as px用于导入plotly.express模块并给它起一个别名px。这样在后续的代码中&#xff0c;你可以使用px来代替plotly.express&#xff0c;使代码更加简洁。 plotly.express是Plotly的一个子模块&#xff0c;用于快速创…

Unity 代码控制Text自适应文本高度

在使用代码给Text赋值时&#xff0c;且文本有多段&#xff0c;并需要根据实际文本高度适配Text组件的高度时&#xff0c;可以使用以下方法&#xff1a; //Text文本 public TextMeshProUGUI text;void Start() {//代码赋值文本text.text "好!\n很好!\n非常好!";//获…

音视频学习(二十二)——rtmp发流(tcp方式)

前言 本文主要介绍自研的RtmpStreamSender.dll&#xff0c;rtmp库提供接口接收裸流数据&#xff0c;支持将裸流数据封装为flv格式并通过rtmp协议发流。 关于rtmp协议基础介绍可查看&#xff1a;https://blog.csdn.net/www_dong/article/details/131026072 关于rtmp收流介绍可…

C语言中关于if else的理解

if else我们可以理解为 if(条件1) //如果条件1成立 语句1&#xff1b; //执行语句1 else //如果条件1不成立 语句2; //执行语句2 这是一个经典的if els…