SourceTree配置多个不同Remote地址的仓库

news2025/1/12 13:32:38

需求

在我们开发过程中,有可能需要拉取的地址仓库不在同一个仓库中,有些可能在Github上,有些可能在Gitlab上。

所以我们需要配置Github的仓库的配置和Gitlab仓库的配置。

现在,我们来配置两个不同的仓库的地址。

假设:

Gilab地址:http://192.168.3.100/group/testRemo1.git

Github地址:https://github.com/username/testRemo2.git

其中:

group:Gitlab服务器上对于的群组名;testRemo1:仓库(在Gitlab后台上称为项目)名。

username:Github远程仓库拥有者的用户名(注意是拥有者的Github用户名,不是我们自己的,之后我们还需要有自己的Github账户);testRemo2:仓库名。

正常情况下:

Gitlab:我们使用gitlab可以使用我们自己的用户名和密码去拉取远程仓库。

Github:我们使用ssh key配置来拉取远程仓库。

添加多份SSH Key配置

在GitBash上执行:

ssh-keygen -t rsa -C "your_email@example.com" -f ~/.ssh/id_rsa_repo1

ssh-keygen -t rsa -C "your_email@example.com" -f ~/.ssh/id_rsa_repo2

这里的“your_email@example.com”替换为自己的邮箱地址。

执行了这两个命令之后,在Windows的C:/用户/“自己的用户名”/.ssh/目录上就会多了几个文件,其中包括:

id_rsa_repo1

id_rsa_repo1.pub

id_rsa_repo2

id_rsa_repo2.pub

这里的“id_rsa_repo1.pub”是为Gitlab准备的,但是我们拉取Gitlab上的仓库是使用用户名和密码去拉取,所以这个暂时是不需要到的。

这里的“id_rsa_repo2.pub”是为Github准备的,等一下我们需要把这个文件里的内容复制到我们自己的Github账户SSHKey配置中。

Tips:既然不需要到id_rsa_repo1相关文件,那我们为什么还去创建他,因为我们可以经过这样的对比来了解在不同的仓库下的配置处理,这样之后如果想把Gitlab配置成SSH,就知道如何处理了。

再在GitBash上执行

ssh-add ~/.ssh/id_rsa_repo1

ssh-add ~/.ssh/id_rsa_repo2

在执行“ssh-add”时,可能会出现报错:

Could not open a connection to your authentication agent

可以执行

eval $(ssh-agent)

来启动ssh代理。

在Github中配置SSH

选择“SSH and GPG keys”可以看到,我这里已经配置了一个SSH Key了。

这个Key的SHA256码为:MSq1PY5oQPsvNij4DpM/nO...............

各位看官的这个列表里应该是没有这个Key的,所以我们现在来配置一下。

点击“New SSH key”

Tittle随便填什么。

Key里的内容,我们就打开“id_rsa_repo2.pub”文件,把里面的内容全部复制出来,粘贴到这里。

这样,我们就有了一个Key了。

在SourceTree配置

现在我们在SourceTree添加Github账户,点击“工具”-》“选项”-》“验证”切页,然后再点击“添加”,则出现以下界面。

然后再“托管服务商”总选择“Github”,再点击“刷新 OAuth令牌”。

会跳转到我们自己的Github账户中。

然后再点击“Authorize altassian”按钮,即可授权成功。

这样就添加了一个自己的Github账户

然后,Github的仓库拥有者就可以给我们一个权限。我们就可以拉取远程仓库了。

拉取远程仓库

注意:

全程操作应该有科学上网支持。

但是即使有科学上网支持,我们还是可能使用git clone命令拉取不了远程仓库,这是因为git也要配置代理。

 首先查看当前代理配置

可能你输入git config --global --get http.proxy后,没有任何显示,则你当前没有配置代理。

之后我们需要输入

git config --global http.proxy 127.0.0.1:29290

git config --global http2.proxy 127.0.0.1:29290

127.0.0.1:29290可以修改为你任意的代理地址。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

快速体验LLaMA-Factory 私有化部署和高效微调Llama3模型FAQ

序言 之前已经介绍了在超算互联网平台SCNet上使用异构加速卡AI 显存64GB PCIE,私有化部署Llama3模型,并对 Llama3-8B-Instruct 模型进行 LoRA 微调、推理和合并 ,详细内容请参考另一篇博客:快速体验LLaMA-Factory 私有化部署和高…

Android14音频进阶之命令行播放音频(八十)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 新书发布:《Android系统多媒体进阶实战》🚀 优质专栏: Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏: 多媒体系统工程师系列【原创干货持续更…

SpringDI(依赖注入)的理解

目录 一、什么是SpringDI? 二、SpringDI(依赖注入)的作用是什么? 三、DI的实现方式 3.1 set注入 1.项目结构: 2.set注入对象 2.1applicationContext.xml: 2.2 Student 实体类 2.3 controller: 2.4 da…

SpringIOC容器对Bean管理

一、bean实例化 1.通过构造方法(默认) 2.通过工厂方法 3.通过静态工厂方法 项目结构: 1. 通过构造方法(默认) 1.1 pojo实体类: Student: public class Student {public Student() {System.out.println…

软件安全测试报告内容和作用简析,软件测试服务供应商推荐

在数字化时代,软件安全问题愈发凸显,安全测试显得尤为重要。软件安全测试报告是对软件系统在安全性方面进行评估和分析后的书面文件。该报告通常包含测试过程、测试发现、漏洞描述、风险评估及改进建议等重要信息。报告的目的是为了帮助开发团队及时发现…

各种排序算法【持续更新中.....】

1.归并排序 归并排序 ,归并排序是采用分治法(Divide and Conquer)的一个非常典型的应用,所以我们先来说一下什么是分治法。 分治法 定义 分治(英语:Divide and Conquer),字面上的解释是「分…

C++初阶大全

目录 一.命名空间 1.命名空间定义 2.命名空间使用 二.C输入&输出 三.缺省参数 四. 函数重载 五.引用 1.常引用 2.传值、传引用效率比较 3.引用和指针的区别 4.引用和指针的不同点: 小知识点: 六.内联函数 七.auto关键字(C11) 1.auto的使用细则 八.基于范围…

为何你的进销存系统买来却成了摆设?教你7大招解决!

我做企业数字化系统9年,调研的企业大大小小也有几十家了。我发现个挺扎心的现象:有三成企业买的进销存系统,最后都成了闲置的“高科技装饰品”。为啥这些企业舍得掏腰包,到头来却让它们吃灰呢? 说到底,就一…

开源免费的wiki知识库

开源的Wiki知识库有多种选择,它们各自具有不同的特点和优势,适用于不同的场景和需求。以下是一些主流的开源Wiki知识库系统: MediaWiki 简介:MediaWiki是使用PHP编写的免费开源Wiki软件包,是Wikipedia和其他Wikimedia…

达梦数据库的系统视图v$mem_reginfo

达梦数据库的系统视图v$mem_reginfo 达梦数据库的V$MEM_REGINFO视图提供了系统当前已分配但未释放的内存信息。这个视图在MEMORY_LEAK_CHECK参数设置为1时才会注册信息,用于监控内存的申请和释放情况。通过查询V$MEM_REGINFO视图,可以关注REFNUM字段&am…

跟《经济学人》学英文:2024年08月03日这期 Britain’s railways go from one extreme to another

Britain’s railways go from one extreme to another Departing: privatisation. Destination: centralisation 出发:私有化。目的地:集中化 depart:出发 privatisation:美 [ˌpraɪvətaɪ’zeɪʃən] 私有化;民营化;私营化…

IO进程—进程间的通信—共享内存具体函数操作

创建唯一key值—— ftok key_t ftok(const char *pathname, int proj_id); #include <sys/types.h> #include <sys/ipc.h> 功能&#xff1a; ftok函数是用于生成一个键值&#xff08;key_t类型&#xff09;的函数&#xff0c;这个键值通常用于进程间通信&#xff0…

人像修复-通道磨皮

文章目录 原理步骤建立动作一键操作 原理 皮肤看起来比较脏的原因&#xff1a;光影过渡不均匀 步骤 在通道中&#xff0c;找到明暗反差最大的通道&#xff0c;复制一层通道 在复制通道中&#xff0c;用高反差保留&#xff0c;把画面中反差较大的部分保留出来&#xff0c;半…

解决使用Navicat连接数据库时,打开数据库表很慢的问题

今天使用Navicat连接数据库时&#xff0c;发现不管表中数据多少&#xff0c;打开数据库表非常慢。 解决方法&#xff1a; Navicat - 右键编辑数据库连接 - 高级 - 勾选保持连接间隔 - 输入框设置为20 - 点击确定&#xff01; 参考文章&#xff1a;https://51.ruyo.net/14030.…

【ARM】v8架构programmer guide(2)_处理器及V8基础

目录 2.1 ARMv8-A 3. ARMv8的基础 普通世界&#xff08;Non-secure state&#xff09;的特权组件&#xff1a; 安全世界&#xff08;Secure state&#xff09;的特权组件&#xff1a; 安全监视器&#xff08;Secure Monitor&#xff09;&#xff1a; 3.1 execution state…

实现高级社会的构想-基于人工智能模式

实现高级社会(共产主义)的构想 刚过完劳动节,劳动最光荣.在新质生产力思想启发下,我想探讨的是我们当下能否从资本主义或社会主义进入或构建高级社会(共产主义社会)呢?高级社会(共产主义),我的理解可以用平均主义来无限接近,即使政策上无法做到平均分配&#xff0c;也可以通过…

lvs的nat模式配置

lvs的nat模式 准备工作 lvs主机需要两个网络适配器&#xff0c;其中一个为NAT模式&#xff0c;另外一个为仅主机模式&#xff0c;还需要两个server主机&#xff0c;一个为server1还有一个为server2&#xff0c;都为仅主机模式 配置过程 配置ip lvs主机 [rootlvs ~]# cat /…

项目中引入RedisTemplate和Redisson时RedisTemplate无法使用zset问题(栈溢出stackOverflow)深入源码分析解决

文章目录 项目中引入RedisTemplate和Redisson时RedisTemplate无法使用zset问题&#xff08;栈溢出stackOverflow&#xff09;深入源码分析解决依赖信息报错信息与分析解决办法 项目中引入RedisTemplate和Redisson时RedisTemplate无法使用zset问题&#xff08;栈溢出stackOverfl…

utf-8‘ codec can‘t decode byte 0xd3 in position

1.背景 安装psycopg2-binary&#xff0c;安装命令“pip install psycopg2-binary2.9.7” 完整报错信息如下&#xff1a; (venv) PS D:\workspace_all\pyCharm\MaxKB-main> pip install psycopg2-binary2.9.7 Looking in indexes: https://mirrors.ustc.edu.cn/pypi/web/s…

Python语法重温1

最近做项目的时候&#xff0c;有时总得愣一下语法。所以决定来温习一下。。。 温故而知新&#xff0c;谁都没办法说自己经历时间的流逝后还能时刻记得&#xff0c;希望能帮到你们 列表的替换 如果超出列表元素则会报错。 列表末尾的追加 插入列表操作 可以超出列表之外插入 删…