Git | 远程操作

本文详细介绍了Git的分布式版本控制原理,包括创建远程仓库、克隆与推送至远程、本地拉取、配置Git忽略文件和别名,以及标签的管理。重点讲解了通过HTTPS和SSH方式操作远程仓库的方法以及如何在Git中正确使用标签。
摘要由CSDN通过智能技术生成

Git | 远程操作

0、分布式版本控制系统概念

Git是一个分布式版本控制系统,可以进行多人协作开发。

一个团队中每个人的电脑都是一个完整的版本库,一个版本库控制系统有一台充当中央服务器的电脑,用来方便交换、同步彼此之间的修改。与此同时还能一定程度上避免因为本地故障而阻塞项目进度,例如硬盘损坏而导致的文件丢失。

这里的起着中央服务器的电脑通常不用我们自己花钱去购买,目前比较主流使用gitee或者github这样提供Git仓库托管服务的网站,在上边同步远程仓库。

基于本地网络情况以及访问效率上来讲,这里使用的是gitee。

1、创建远程仓库

具体步骤如下:

  1. 进入gitee官网,注册并登录,点击导航栏右上角的加号,点击新建仓库在这里插入图片描述

  2. 填写基本信息建议仓库名填成英文的,路径会自动映射上去,仓库介绍为非必填项,一开始可以先设置成私有的;初始化仓库的话可以选择语言,练习的时候不选择也可以;设置模版中ReadMe文件勾选之后项目初始化时会多个Readme文件和Readme.en文件【英文】(一般为仓库的使用说明文档),后边的不选择也可以。在这里插入图片描述

  3. 点击创建

补充:后续更改仓库的开源状态或者更改仓库信息,点击仓库里的管理:在这里插入图片描述

2、克隆远程仓库

clone/download远程仓库到本地(windows/linux本地),需要使用git clone命令。(这里贴的是windows的,但linux的跟这个差不多)(ps,只有这里贴的是windows的,其他的都是LinuxOS的)

一般来说,克隆远程仓库有两种方式

  1. 通过https方式
  2. 通过ssh方式

上边这两种方式,是git最常使用的数据传输协议

https方式

  1. 复制命令到终端执行【点击到对应文件夹这里是e盘,右键git bash那里,粘贴并敲下回车】在这里插入图片描述

  2. 再次查看e盘,发现已经克隆下来在这里插入图片描述

为方便演示,这里我先将clone下来的仓库删除。

ssh方式

ssh协议使用公钥加密和公钥登录机制,因此,相较于使用https,使用此协议多了一步——将我们的公钥放在服务器上,由Git服务器进行管理。

  1. 拿到自己的公钥

    1. 输入ll -a,查看当前仓库目录中有没有.ssh目录,.ssh目录下有没有id_rsa和id_rsa.pub两个文件

    2. 若有,则跳过生成公钥和私钥的步骤,若没有,输入ssh-keygen -t rsa -C "xxx@qq.com"生成

    3. 此时再次查看ll -a,进入.ssh目录

      这里存在一种情况,就是你的git装到了其他盘,可能生成的文件在对应的路径下,此时再查看的时候可以通过路径信息查看对应的信息

    4. 查看id_rsa.pub(公钥),并复制

  2. 添加自己的公钥到远程仓库

    设置–》安全设置–》SSH公钥

    标题:可以使用mykey(实际上随便命名) 公钥部分将从文件中查到的内容原原本本复制上去,点击确定

  3. 再次复制ssh方式的clone命令执行

3、推送至远程仓库

这里因为之前配置原因,已经手动将本地库与远程的remote-gitcode做了连接,但是后续又进行了test_factory1的克隆,最终还是推送到了remote-gitcode上,精力原因不再修改。

对于windows来说推送到远程可以通过图形化界面方式(需要用小乌龟)和非图形化界面的方式,而对于Linux来说一般就是通过git命令进行操作,这里主要说的是非图形化界面方式即命令行方式。

推送之前我们需要确保已经将gitee账户的姓名和邮箱配置上去了,查看方式:

git config -l在这里插入图片描述

以将版本库中的file5push到远程为例:

  1. 创建并编辑file5
  2. add file5 commit file5
  3. push file5在这里插入图片描述

其中git push origin master:master,origin是远程主机名,后边是本地分支名:远程分支名

这里有两个文件被修改是因为我之前就连接过其他仓库remote-gitcode,又在这个仓库下克隆的test_factory1,所以相当于是把内容推送到remote-gitcode上去了。

如果想推送到test_factory1上可以单独找一个目录进行克隆并提交和push,整体流程是这样,不再演示。

4、本地拉取远程仓库

在gitee上边修改ReadMe文件(实际工作中最好不要动,这里只是模拟),本地拉取远程的文件:

git pull origin master:master

其中本地分支名和远程分支名相同时,可以省略远程分支名

5、配置Git

忽略特殊文件

背景:不想提交保存数据库密码的配置文件,就不让git追踪管理某些文件

解决:git工作区中有个.gitignore文件

  1. vim .gitignore

    # 省略选择模本的内容
    ...
    # My configurations:
    *.ini
    *.so
    
  2. git add .

  3. git commit - m "add .gitignore"

  4. git push origin maser

这样操作后,即使我们修改了ini文件,它也不会被追踪,so文件同理

使用的过程中可能存在以下情况

  1. 我们想强制添加一个已经被忽略的文件:git add -f [filename]

  2. 查看被忽略的文件到底是哪里设置了:git check-ignore -v a.so

  3. .gitignore已经配置忽略so文件,但是希望不忽略a.so文件:

    例外规则:!文件名==》!a.so

给命令配置别名

  1. 将git status简化为git st:git config --global alias.st status
  2. 显示最后一次提交信息:git config --global alias.last 'log -1'

配置完别名,原来的也可以使用

6、标签管理

标签是对某次commit的标识,eg:v1,v2,

版本包或许与这里有些联系,版本号或许就是标签?

标签可以通过远程仓库查看在这里插入图片描述

创建标签

1、初试

  1. 切换到需要打标签的分支上:git branch【打当前的分支的当前版本】
  2. git tag [name]:这里以v1.0为例
  3. git tag查看所有标签
  4. 之后可以通过git push origin <tagname>提交,然后在远程就可以看到了

2、在指定版本的commit上打标签:

  1. 首先找到想要打标签的历史版本,可以通过查日志的方式:git log --pretty=oneline --abbrev-commit
  2. 对这次提交打标签(若标签名为v0.7):git tag v0.7 部分或全部commitid
  3. 通过git tag查看:【标签不是按时间给的,是按照字母排序的】

另外,可以通过git show [tagname]查看标签信息

操作标签

创建的标签只会存储在本地,不会自动推送到远程。

  1. 如果操作错误想删除,可以执行git tag -d [tagname];

  2. 如果想要提交,执行git push origin <tagname>即可

  3. 想要删除已经推送到远程的标签

    1. 先本地删除:git tag -d [tagname]
    2. 再从远程删除:git push origin :refs/tags/[tagname]
      tag -d [tagname]`;
  • 15
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值