Git的原理和使用(四)

目录

远程操作

理解分布式版本控制系统

远程仓库

新建远程仓库

克隆远程仓库

向远程仓库推送

拉取远程仓库

配置Git

忽略特殊文件

为命令配置别名

标签管理

理解标签

创建标签

操作标签


远程操作

理解分布式版本控制系统

1、每个人的电脑上都是一个完整的版本库,这样工作的时候就不需要联网了,因为版本库就在你自己的电脑上,既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比如说你在自己电脑上更改了文件A,你的同事也在他的电脑上更改了文件A,这时你俩之间只需要把各自的修改推送给对方,就可以互相看到对方的修改了

2、分布式版本控制系统的安全性很高,因为每个人电脑里都有完整的版本库,某一个人的电脑坏了不要紧,随便从其他人哪里复制一个即可

3、在实际使用分布式版本控制系统时,其实很少在两个人的电脑上推送版本库的修改,因为可能你俩不在同一局域网内,两台电脑互相访问不了,也可能今天你的同时病了,他的电脑根本没开机,因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅说同来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已,而且有了它就不怕本地出什么故障了(硬盘损害,上面的内容丢失之类的)

远程仓库

新建远程仓库

网址:Gitee - 基于 Git 的代码托管和研发协作平台

填写基本信息,创建成功: 

在新建库的.gitee中查看所选的两个文件的作用: 

  • Issue文件:发现本仓库问题的外来者与仓库成员交流的文件

  • Pull Request文件: 实际开发中开发分支dev不能直接和主分支master进行merge防止错误的开发内容影响master分支,该文件就是一个用于向管理员提交合并申请的申请单

远程仓库是有成员的

克隆远程仓库

指令:git clone + 远程仓库链接

        SSH协议和HTTP协议是Git最常用的两种数据传输协议,SSH协议使用了公钥加密和公钥登录机制,体现了其实用性和安全性,使用此协议需要将我们的公钥放在服务器,由Git服务器进行管理,使用HTTPS方式时没有要求可以直接克隆:

  • HTTP方式:

注意事项:不能在本地仓库所在的目录下执行clone指令

 远程仓库的默认名字是origin,通过git remote指令查看,加上选项-v查看更详细内容

  • SSH方式:
  • 在用户主目录的隐藏文件中是否有.ssh目录,如果有查看是否有id_rsa和id_rsa.pub这两个文件,如果有则不用创建SSH Ket,否则需要用ssh-keygen -t  rsa -C “邮箱”指令进行创建

当我们从远程仓库克隆后,Git会自动把本地的master分支和远程的master分支建立链接

向远程仓库推送

git config -l查看仓库配置,本地仓库的username和useremail要与gitee中的一致否则报错:

在本地仓库remote_gitcode中新增一个file.txt文件,并提交给当前分支:

用git push指令将本地仓库的master分支上新增的修改内容推送到远程仓库的master分支上:

  • git push <远程主机名> <本地分支名>:<远程分支名>
  • git push <远程主机名> <本地分支名>(本地分支名与远程分支名一致可省略冒号)

使用SSH方式推送时不用输入账号密码,使用HTTP方式时需要:

拉取远程仓库

在gitee上点击README.md文件并在线修改它:

        此时远程仓库是要领先于本地仓库一个版本,为了使本地仓库保持最新的版本,我们需要拉取下远端代码,并合并到本地,Git提供了git pull命令该命令用于从远程获取代码并合并本地的版本,格式如下:

  • git pull <远程主机名> <远程分支名>:<本地分支名>
  • git pull <远程主机名> <远程分支名>(远程分支是与当前分支合并,则冒号后部分可省略)

配置Git

忽略特殊文件

在日常开发中,我们有哪些文件不想或者不应该提交到远端仓库,比如保存了数据库密码的配置文件,那么该如何让Git知道呢?在Git工作区根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件了(.gitignore文件gitee在创建仓库时就可以为我们生成,不过需要我们主动勾选一下)

如果没有该选项,在工作区创建一个也是可以的,无论哪种方式最终都可以得到一个完整的.gitignore文件,例如我们想忽略.so和.ini结尾的所有文件,.gitignore中的内容如下:

#省略选择模本的内容
...#MY configurations:
*.ini //隐藏以.ini和.so结尾的文件
*.so

在.gitignore文件中也可以指定某个确定的文件,最后将该文件提交到远程仓库即可:

        检验.gitignore的标准就是git status命令是不是说working tree clean,如果是则.gitignore文件生效,但是有些时候如果再想添加一个文件到Git,但由于该文件被.gitignore忽略了,根本添加不进去,就可以用-f强制添加:

  • git add -f 文件名

或者是.gitignore写的有问题,需要找出来哪个规则写错了,比如a.so文件是要被添加的而不是忽略的,可以用git check-ignore命令检查:

Git会告诉我们.gitignore的第六行规则忽略了该文件,于是我们就知道应该修订哪个规则,还有些时候当我们编写了规则排除了部分文件时:

#排除所有.开头的隐藏文件:
.*

.*这个规则把.gitignore也排除了,虽然可以用git add -f指令强制添加进去 ,但是最好还是别破坏.gitignore规则,这时可以添加一条例外规则,将指定文件排除在.gitignore规则外的写法就是!+文件名,所以只需把例外文件添加进去即可:

#排除所有.开头的隐藏文件;
.*#不排除.gitignore
!.gitignore

为命令配置别名

基本概念:有些Git命令太长,为此git支持对命令进行简化

简化指令:git config [选项] alias.别名 原

        --global选项是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有,如果不加则只针对当前仓库起作用

标签管理

理解标签

        标签tag可以简单理解为是对某次commit的一个表示,相当于起了一个别名,例如在项目发布某个版本时,针对最后一次commit起一个v1.0这样的标签来标识里程碑的意义。相较于难以记住的commit id,tag可以很好的解决这一问题,因为tag一定要给一个让然容易记住且有意义的名字,当我们需要回退到某个重要版本时,直接使用标签就能很快定位到

创建标签

切换到需要打标签的分支上并为该分支打标签,git log可以查看所有标签:

        默认标签是打在最新提交的commit上的,在指定的commit上打标签可以通过找到历史提交的commit id然后打上标签即可:

注意,标签不是按时间顺序列出,而是按字母排序的,可以用git show [tagname]查看标签信息:

Git还提供可以创建带有说明的标签,用-a指定标签名,-m指定说明文字:

git tag -a [name] -m "xxx" [commit_id]

打完标签后可以使用tree .git指令查看本地库的变化: 

操作标签

如果标签打错了,也可以用git tag -d [标签] 指令删除:

因为创建标签都只存储在本地,不会自动推送到远程,所以打错的标签可以在本地安全删除,如果要推送某个标签到远程,使用git push origin <tagname>指令即可:

此时,查看远程仓库,看到标签已经被更新:

如果本地标签很多,可以用git push origin --tags指令一次性全部推送到远端:

如果标签已经推送到远端,要删除远程标签就麻烦一点,要先从本地删除,然后再从远程删除,删除命令也是push,但是格式不一样:

删除成功:

~over~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/285108.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

qt Qt Remote Object(QtRO)实现进程间通信

简介 Qt Remote Object简称QtRO&#xff0c;这是Qt5.9以后官方推出来的新模块&#xff0c;专门用于进程间通信&#xff08;IPC&#xff09;。是基于Socket来封装的&#xff0c;兼容LPC和RPC。LPC即Local Process Communication&#xff0c;而RPC是指Remote Process Communicat…

电子电器架构 —— 诊断数据DTC具体故障篇

电子电器架构 —— 诊断数据DTC起始篇 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师 (Wechat:gongkenan2013)。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自己。江湖一碗茶,喝完再挣扎…

【Postman】工具使用介绍

一、postman工具介绍 1.什么是postman postman是谷歌开发的一款网页调试和接口测试工具&#xff0c;能够发送任何请求类型的http请求&#xff0c;支持GET/POST/PUT/DELETE等方法。postman简单易用&#xff0c;可以直接填写URL&#xff0c;header&#xff0c;body就可以发送一…

二次开发Flink-coGroup算子支持迟到数据通过测输出流提取

1.背景 coGroup算子开窗到时间关闭之后&#xff0c;迟到数据无法通过测输出流提取&#xff0c;intervalJoin算子提供了api&#xff0c;因为join算子底层就是coGroup算子&#xff0c;所以Join算子也不行。 flink版本 v1.17.1 2.coGroup算子源码分析 2.1完成的coGroup算子调用流…

SpringCloud中网关实现笔记

SpringCloud中网关实现笔记 SpringCloudGateway&#xff1a;基于Spring的WebFlux技术&#xff0c;完全支持响应式编程&#xff0c;吞吐能力更强 Spring Cloud Gateway 是 Spring Cloud 的一个全新项目&#xff0c;用于构建基于 Spring 框架的 API 网关服务。它基于 Spring 5&a…

Python爬虫-批量爬取星巴克全国门店

前言 本文是该专栏的第22篇,后面会持续分享python爬虫干货知识,记得关注。 本文笔者以星巴克为例,通过Python实现批量爬取目标城市的门店数据以及全国的门店数据。 具体的详细思路以及代码实现逻辑,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM…

基于SpringBoot和Vue的课程作业管理系统的设计与实现

今天要和大家聊的是一款基于SpringBoot和Vue的课程作业管理系统的设计与实现。 &#xff01;&#xff01;&#xff01; 有需要的小伙伴可以通过文章末尾名片咨询我哦&#xff01;&#xff01;&#xff01; &#x1f495;&#x1f495;作者&#xff1a;李同学 &#x1f495;&am…

福昕阅读器 PDF 文档基本操作

福昕阅读器 PDF 文档基本操作 References 转至 PDF 顶部 快捷键&#xff1a;Home. 转至 PDF 顶部 快捷键&#xff1a;End. 打开超链接 文本选择工具 -> 手形工具 (Hand Tool) -> 点击超链接 福昕阅读器 同时在多个窗口中打开多个文件 文件 -> 偏好设置 -> 文…

开源博客项目Blog .NET Core源码学习(10:App.Framwork项目结构分析)

开源博客项目Blog的解决方案总共包括4个项目&#xff0c;其中App.Hosting项目包括所有的页面及控制器类&#xff0c;其它项目主要提供数据库访问、基础类型定义等。这四个项目的依赖关系如下图所示&#xff0c;本文主要分析App.Framwork项目的主要结构及主要文件的用途。   …

老胡的周刊(第134期)

老胡的信息周刊[1]&#xff0c;记录这周我看到的有价值的信息&#xff0c;主要针对计算机领域&#xff0c;内容主题极大程度被我个人喜好主导。这个项目核心目的在于记录让自己有印象的信息做一个留存以及共享。 &#x1f3af; 项目 Llama-Chinese[2] 专注于 Llama 模型在中文方…

nodejs+vue高校社团管理小程序的设计与实现python-flask-django-php

相比于以前的传统手工管理方式&#xff0c;智能化的管理方式可以大幅降低学校的运营人员成本&#xff0c;实现了高校社团管理的标准化、制度化、程序化的管理&#xff0c;有效地防止了高校社团管理的随意管理&#xff0c;提高了信息的处理速度和精确度&#xff0c;能够及时、准…

sentinel中StatisticSlot数据采集的原理

StatisticSlot数据采集的原理 时间窗口 固定窗口 在固定的时间窗口内&#xff0c;可以允许固定数量的请求进入&#xff1b;超过数量就拒绝或者排队&#xff0c;等下一个时间段进入, 如下图 时间窗长度划分为1秒 单个时间窗的请求阈值为3 上述存在一个问题, 假如9:18:04:…

8个常见的数据可视化错误以及如何避免它们

在当今以数据驱动为主导的世界里&#xff0c;清晰且具有洞察力的数据可视化至关重要。然而&#xff0c;在创建数据可视化时很容易犯错误&#xff0c;这可能导致对数据的错误解读。本文将探讨一些常见的糟糕数据可视化示例&#xff0c;并提供如何避免这些错误的建议。 本文总结了…

前端学习之用css和html做一个仿淘宝的导航栏

代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>仿淘宝界面案例</title><style>/* 最外层盒子 */.container{width: 270px;height: 385px;border: 1px solid rgb(255, 208, 0);bord…

服务消费微服务

文章目录 1.示意图2.环境搭建1.创建会员消费微服务模块2.删除不必要的两个文件3.检查父子模块的pom.xml文件1.子模块2.父模块 4.pom.xml 添加依赖&#xff08;刷新&#xff09;5.application.yml 配置监听端口和服务名6.com/sun/springcloud/MemberConsumerApplication.java 创…

LeetCode每日一题——移除链表元素

移除链表元素OJ链接&#xff1a;203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 思路&#xff1a; 这与之前的移除元素的题目很相似&#xff0c;那么我们同样可以用类似的做法&#xff08;双指针&#xff09;进行解题。但是这是一个链表删除&a…

代码随想录算法训练营Day56 ||leetCode 583. 两个字符串的删除操作 || 72. 编辑距离

647. 回文子串 dp[i][j]表示第i位开始&#xff0c;第j位结束的字符串是否为回文串 class Solution { public:int countSubstrings(string s) {vector<vector<bool>> dp(s.size(), vector<bool>(s.size(), false));int result 0;for (int i s.size() - 1…

大白话扩散模型(无公式版)

背景 传统的图像生成模型有GAN&#xff0c;VAE等&#xff0c;但是存在模式坍缩&#xff0c;即生成图片缺乏多样性&#xff0c;这是因为模型本身结构导致的。而扩散模型拥有训练稳定&#xff0c;保持图像多样性等特点&#xff0c;逐渐成为现在AIGC领域的主流。 扩散模型 正如…

笔记本和台式机主板内部结构分析

笔记本和态势机主板内存接口以及配件安装位置 笔记本主板 1 以thinkpad L-490为例,使用拆机小工具拆机&#xff0c;打开后面板&#xff0c;内部结构示意图如下 台式机主板 以技嘉-B660M-AORUS-PRO-AX型号主板为例 笔记本电脑和台式机电脑的相同之处 CPU&#xff1a;笔记本…

牛客题霸-SQL篇(刷题记录三)

本文基于前段时间学习总结的 MySQL 相关的查询语法&#xff0c;在牛客网找了相应的 MySQL 题目进行练习&#xff0c;以便加强对于 MySQL 查询语法的理解和应用。 由于涉及到的数据库表较多&#xff0c;因此本文不再展示&#xff0c;只提供 MySQL 代码与示例输出。 以下内容是…