配置本地Git从Gitlab上拉取项目
创始人
2024-04-22 19:43:23
0

配置本地Git从Gitlab上拉取项目

安装git:
https://git-scm.com/downloads
git官网下载安装包,安装时一路next即可

①配置用户名,邮箱

  • 创建一个文件夹,任意位置即可
  • 鼠标右键选择,git bash here
  • 配置提交人姓名、邮箱
git config --global user.name 提交人姓名(自取)
git config --global user.email 提交人邮箱(自己邮箱)

查看配置结果:

git config --list

在这里插入图片描述

②配置登录方式

2.1 配置SSH方式

为实现免登录效果,使用ssh实现身份验证,不需要提供用户名和密码。依据公钥私钥配对实现免登录。

  1. 生成密钥:
ssh-keygen -t rsa -C "您的邮箱地址"

回车后会提示您密钥生成位置–用户文件下生成.shh文件。打开.ssh文件,即可查看私钥和公钥
2. 进入密钥目录查看密钥

cd ~/.ssh
  1. 查看密钥,并复制密钥,将其配置到GitLab上
cat id_rsa.pub

在这里插入图片描述
4. 复制公钥:复制公钥到gitlab上。私钥保留在开发者上。实现连接认证

把刚刚 copy 的秘钥复制进去,取个名字,完成添加~

在这里插入图片描述
5. 验证是否成功

输入 ssh -T git@github.com
如果打印类似如下信息,即完成:
Hi xxxx! You’ve successfully authenticated, but GitHub does not provide shell access.

2.2 配置HTTPS方式

https的方式不用过多的配置,只需要配置本地git的username和email即可

③Gitee与GitHub同时配置ssh

3.1 Gitee配置ssh访问

  1. 设置用户名、邮箱为gitee上绑定的邮箱
git config --global user.name "yourname@yourgitee.com"
git config --global user.email "youremail@yourgitee.com"

用户名、邮箱自取

  1. 配置生成ssh密钥
ssh-keygen -t rsa -C "youremail@yourgitee.com"

在这里插入图片描述

  • 生成密钥的时候,会询问你存放文件名,这个地方自取,只要自己能辨别即可,比如如果我们是配置gitee的,并且用rsa加密,可以取名为id_rsa_gitee
  • 每次生成密钥都会生成对应的id_rsa与id_rsa.pub文件,id_rsa.pub存放公钥【存放目录在家目录下.ssh文件】
    在这里插入图片描述
  1. 通过git命令行进入存放公私钥的位置
cd ~/.ssh
  1. 查看开始生成的公钥,并配置到gitee上
cat id_rsa_gitee.pub

注意:前面的ssh-rsa也要带上
在这里插入图片描述
5. 登录gitee,个人中心 - 安全设置 - SSH公钥 - 添加公钥
在这里插入图片描述
6. 将私钥添加到本地ssh列表

ssh-add ~/.ssh/id_rsa_gitee

如果执行ssh-add时提示"Could not open a connection to your authentication agent",可以现执行命令:

ssh-agent bash

然后再运行ssh-add命令。

可以通过 ssh-add -l 来确私钥列表

ssh-add -l

可以通过 ssh-add -D 来清空私钥列表

ssh-add -D

注意如果我们是要配置多个ssh,一定要将多个私钥添加进去

在这里插入图片描述
7. 创建配置文件config(注意:config无后缀名)

touch config
vim config

通过i然后复制如下内容,然后:wq保存并退出【如果对vim不熟悉的同学,也可以直接通过windows图形化操作】

config文件(下面的配置按需修改即可):

# gitlab
Host gitlab.comHostName gitlab.comPreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa_gitlab# gitee
Host gitee.comHostName gitee.comPreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa_gitee# github
Host github.comHostName github.comPreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa_github
  1. 测试是否配置成功
ssh -T git@gitee.com

在这里插入图片描述

  • 如果我们在测试过程中询问我们是否建立连接,直接输入yes
    在这里插入图片描述
    其目的主要是在.ssh目录:C:\Users\夏末\.ssh生成对应的两个文件
    在这里插入图片描述

如果还有其他错误的话,可以通过ssh -Tvvv git@gitee.com以debug方式来显示执行过程,然后排查错误

3.2 配置github

配置都大同小异,此处我就只给命令了

  1. 用户名、邮箱
git config --global user.name "yourname@yourgithub.com"
git config --global user.email "youremail@yourgithub.com"
  1. 进入.ssh目录,生成密钥
cd ~/.ssh
ssh-keygen -t rsa -C "youremail@yourgithub.com"
  1. 配置公钥到github
cat id_rsa_github.pub

在这里插入图片描述
4. 添加私钥到本地

ssh-add ~/.ssh/id_rsa_github
  1. 修改config配置文件
# github
Host github.comHostName github.comPreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa_github
  1. 测试
ssh -T git@github.com

Gitlab配置同理:

gitlab配置ssh

  1. 设置好本地username与email
git config --global user.name 提交人姓名(自取)
git config --global user.email 提交人邮箱(自己邮箱)

设置好之后查看结果:
在这里插入图片描述
2. 进入ssh文件夹,生成ssh密钥

cd ~/.ssh
ssh-keygen -t rsa -C "你gitlab上的邮箱地址"

gitlab上的Edit Profile中查看:
在这里插入图片描述

在生成过程中会提示我们文件名称Enter file in which to save the key ,需要记住,文件名称不能和Gitee的重复
让我们输入密码Enter passphrase (empty for no passphrase):,直接回车就行(下面让我们继续输入,直接继续回车)

在这里插入图片描述

  1. 进入ssh私钥地址,查看对应生成好的私钥
    进入ssh私钥存放地址
cd ~/.ssh

在这里插入图片描述
后面同上,不再赘述。

注意:需要根据公司的gitlab访问前缀来配置config
例如:
公司项目的gitlab项目的sms地址:

gitlab@gitlab.ali.com:service/test-sms.git

那么我们需要在config中配置成如下:

# gitlab
Host gitlab.ali.comHostName gitlab.ali.comPreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa_gitlab

对应的,我们测试也需要使用如下命令:

ssh -T gitlab@gitlab.ali.com

拓展:git用户名、邮箱的理解

首先,远程仓库一般支持两种协议:SSH和HTTPS,SSH协议只认机器,HTTPS协议只认账号;也即为:如果使用SSH操作远程仓库的话,我们需要使用公钥和私钥对来做权限的认证,如果使用HTTPS操作远程仓库,则需要使用账号密码来做权限的认证。无论是公钥私钥对,还是账号密码,都只做权限的认证;但是远程仓库里需要记录这些提交记录是由谁来完成的;所以我们需要给本地的git设置用户名和邮箱,用于从本地仓库向远程仓库提交记录时,在远程仓库记录下这些操作是由谁来完成的。

目前有新的协议正在开发,暂时不做讨论

Q/A:
1、为什么要配置用户名和邮箱?

git是分布式版本管理系统,每个机器需要自报家门(username、email),这样
远程仓库才知道哪次提交是由谁完成的。

但是我们git配置的用户名与邮箱都不会进行验证,但是如果真的有人冒充的也是有办法可查的。

2、配置的用户名和邮箱对push代码到远程仓库有什么影响?

仅仅会出现在commits里,用来标识是谁提交了

首先,配置的用户名和邮箱对push代码到远程仓库时的身份验证没有作用,即不用他们进行身份验证;他们仅仅会出现在远程仓库的commits里。

其次,按正常操作来说,你应该配置你的真实用户名和邮箱,这样一来在远程仓库的commits里可以看到哪个操作是你所为。

最后,这个用户名和邮箱是可以随便配置的(不提倡),如果你配置的邮箱是github里真实存在的邮箱,则commits里显示的是这个邮箱对应的账号;如果配置的邮箱是一个在github里不存在的邮箱,则commits里显示的是你配置的用户名。

参考文章:
https://blog.csdn.net/ITWANGBOIT/article/details/103618427

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...