【Git】--- Git远程操作 && 标签管理

发布于:2025-03-26 ⋅ 阅读:(23) ⋅ 点赞:(0)

 Welcome to 9ilk's Code World

       

(๑•́ ₃ •̀๑) 个人主页:       9ilk

(๑•́ ₃ •̀๑) 文章专栏:    Git  


前面我们学习的操作都是在本地仓库进行了,如果团队内多人协作都在本地仓库操作是不行的,此时需要新的解决方案 --- 远程仓库。本篇博客我们将讲解关于远程仓库的一些操作同时介绍一下标签的相关知识。


🏠 Git远程操作

理解分布式版本控制系统

我们目前所说的所有内容(工作区,暂存区,版本库等等),都是在本地!也就是在你的笔记本或者计算机上。而我们的Git其实是分布式版本控制系统!那什么是分布式版本控制系统呢?

实际开发中我们是需要多人协作的,只具备我们之前所讲的分支功能是不足以支撑我们的多人协作开发的。我们之前的操作是在本地开发(即一台服务器上),如果多人开发,我们肯定是希望每个人在属于自己的服务器上开发,此时初步方案是每台服务器上有属于自己的一个完整版本库,团队人员之前只需要把各自的修改推送给对方,就可以互相看到对方的修改了

但这种方案也有其局限性,如果其中一台主机没连上局域网或硬盘损坏导致本地仓库内容全部丢失,此时不易修复,因此有了下面的方案:

这其实就相当于是一个分布式版本控制系统 , 分布式版本控制系统通常也有一台充当"中央服务器"的电脑,但这个服务器的作用仅仅是用来方便"交换"大家的修改,没有它大家也一样干活,每个本地仓库都是完整的,并且可以独立于其他仓库进行操作,远程仓库只是一个共享平台,而不是一个单一的中心,方便多人协作且安全性很高,有了它就不怕本地出现什么故障,出现故障直接拉取即可。

远程仓库

Git是分布式版本控制系统,同一个Git仓库,可以分布到不同机器上。最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以"克隆"这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分。

了解这些之后,我们要明白的是,一台电脑也是可以克隆多个版本库的,只要不是在同一个目录下,但是在一台电脑上克隆几个远程库完成没有意义

实际情况是,找一台电脑充当服务器的角色,每天24h开机,其他每个人都从这个“服务器”仓库克隆一份到自己电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。

我们学习Git需要自己搭建个中间服务器吗?其实不用,国外的GitHub和国内的Gitee网站已经提供Git仓库托管服务了,本篇博客我们以gitee为例来使用远程仓库。

Gitee新建仓库步骤如下:

1. 在首页找到新建仓库选项

2. 设置相关选项

注意:

(1)  一个远程仓库内包含了不同的成员,可以在管理仓库选项进行设置,不同成员对应不同的权限

(2) Git的Issue文件一般是团队开发人员或用户用来报告bug,功能请求的重要工具,帮助开发者发现问题。

(3)Pull Request : 合并申请单。实际开发中,仓库管理员不允许开发者直接将次分支dev合并到master分支,需要提交合并申请单说明合并原因等,管理员看到同意之后才进行合并操作。

克隆远程仓库到本地

要想克隆一个远端仓库到本地,gitee是给我们提供相应操作的:

我们可以看到gitee给我们提供了克隆仓库可以使用的多种数据传输协议。其中,SSH协议HTTPS协议是Git最常使用的两种数据传输协议SSH协议使用了公钥加密和公钥登陆机制,体现了其实用性和安全性,使用此协议需要将我们的公钥放上服务器,Git服务器进行管理。使用HTTPS方式时,没有要求,可以直接克隆下来。

(1)HTTPS

点开克隆仓库选择HTTPS会显示HTTPS远程克隆地址,我们需要将其复制下来:

克隆仓库的指令:

git clone + HTTPS克隆地址

注意:克隆操作不能在任意一个本地仓库下执行!

我们使用ls -a命令查看克隆仓库与远端仓库是相同的:

克隆之后状态如下:

  • origin代表克隆下来仓库的默认仓库名

如果我想查看克隆仓库的信息可以使用git remote命令:

git remote //查看远程仓库
git remote -v 查看更多详细信息

我们可以看到我们克隆下来的仓库具有fetch(拉取权限) 和 push(推送权限)

(2)SSH

同样的,SSH协议也有个对应的克隆地址,但是与HTTPS不同的是,SSH协议采用了公钥加密和公钥登录机制,需要将我们的公钥放上服务器,Git服务器进行管理

我们现在码云的安全设置里查看Git服务器是否配置了公钥:

此时没有配置公钥进行克隆操作是会报错的:

配置公钥:

(1)查看.ssh目录。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有 id_rsa id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,需要创建SSHKey

(2)创建SSH-Key : 

# 注意要输⼊⾃⼰的邮箱,然后⼀路回⻋,使⽤默认值即可
ssh-keygen -t rsa -C "xxxx"

查看.ssh目录是否创建成功:

(3) 打开id_rsa.pub将公钥配置到码云:

cat id_rsa.pub

(4) 克隆

向远程仓库推送

本地已经clone成功远程仓库后,我们便可以向仓库中提交内容。

在推送之前,我们最好将我们克隆仓库的配置项设置好,user.name与user.email和码云保持一致:

我们在本地新建file.txt文件然后进行提交,此时会与我们之前本地新建仓库报出的信息不同:

向远端仓库提交需要使用git push命令:

git push origin master:master //远程仓库 本地分支:远程分支
git push origin master //远程分支与本地分支名相同远程分支可以省略

注意:对于远程仓库的master分支,在克隆的时候git会自动帮我们和克隆仓库建立联系,这样才能push和pull。

拉取远程仓库

拉取操作一般是远端仓库版本领先于当前本地仓库,下面我们进行演示:

(1)在远端仓库编辑文件

注意:实际开发中不要在远程仓库上编辑,这里只是演示需要

(2)从远端仓库中拉取

git pull origin master:master 远程仓库 远程分支:本地分支
git pull origin master //本地分支与master分支名相同可以省略

注意:pull帮我们完成两件事,先将代码拉取,然后merge分支。相当于是git fetch 和 git merge的组合,如果合并有冲突,还需我们自己手动解决。

忽略特殊文件

在日常开发中,我们有些文件不想或者不应该提交到远端,比如保存了数据库密码的配置文件,那怎么让Git知道呢?在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件了。日常开发我们不只改一个文件,可能一次性改多个文件,一般是git add . 此时不想对一个文件add误操作的话.gitignore就是帮我们解决这个问题的。

gitee在我们新建仓库时可以帮我们生成,只不过需要我们进行勾选:

当然你也可以在工作区的根目录下创建一个特殊的.gitignore文件

测试:

如果我们想强制将忽略文件添加,可以带上-f选项:

git add -f //强制将忽略文件添加

但这有点违背我们使用.gitignore的初衷了,我们可以在.gitignore文件中使用 !+文件名 的格式设置不想忽略的:

如果我们想查看一个文件被忽略的原因,可以使用命令:

git check-ignore -v 查看为什么被忽略

这里的意思是被忽略是因为第三行的*.so

配置命令别名

我们发现有些Git命令比较长,幸运的是,Git与Linux一样支持对命令进行简化,即“取别名”。

//在全局给git status取别名
 git config --global alias.st status

此后我们可以使用git st来查看查看状态了:

//补充命令
git log --pretty=oneline --abbrev-commit
//打印出短的commit id

🏠 Git标签管理

标签tag,可以简单的理解为是对某次 commit的一个标识相当于起了一个别名。例如,在项目发布某个版本的时候,针对最后一次 commit 起一个V1.0这样的标签来标识里程碑的意义。

这有什么用呢?相较于难以记住的commit id,tag很好的解决这个问题,因为tag一定要给一个让人容易记住,且有意义的名字。当我们需要回退到某个重要版本时,直接使用标签就能很快定位到

创建标签

git tag v1.0 //默认给最新一次提交打标签
git tag 列举出当前哪些标签存在

查看.git目录变化:

注意 : 默认标签是打在最新提交的commit上的。

如果我想给指定提交打标签呢?

git tag 标签名 + commit id //给指定提交打标签

注意:标签不是按时间顺序列出,而是按字母排序的。

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

git tag -a 标签名 -m "message"  //对标签进行描述
git show 标签名 //查看标签的描述信息

删除标签

git tag -d 标签名

推送标签

(1) 推送指定标签

 git push origin v1.0

打开查看标签信息:

(2) 推送所有标签

git push origin --tags //推送所有标签

(3) 在本地删除远端仓库标签

  • 先在本地删除标签,本地删除也是修改
git tag -d
  • 推送到远端

此时我们发现远端标签成功被删除了:


总结远程仓库相关操作
1. git clone --- 克隆仓库

2. git remote [-v] --- 查看远程仓库信息

3. git push 远程仓库名 本地分支:远程分支 --- 向远程仓库推送

4. git pull 远程仓库 远程分支:本地分支 --- 拉取远程仓库

5. 配置命令别名:git config alias.xxx 命令

总结标签管理

1. git tag 标签名 --- 创建标签

2. git tag --- 查看标签信息

3. git tag -d + 标签 --- 删除标签

4. git push 远程仓库 分支 --- 推送分支