• Git之同一台电脑连接多个远程仓库


    问题描述

    有时候我们需要在同一台电脑上连接多个远程仓库,比如连接两个GitHub账号,那么需要两个条件。
    1.生成两对 私钥/公钥,并且密钥文件命名不能重复。
    2.push 到remote时区分两个账户,推送到相应的仓库。

    相应配置

    1.在MAC的终端中输入以下命令,查看密钥。

    ls ~/.ssh
    

    如果有 id_rsaid_rsa.pub,说明已存在一对密钥/公钥。

    2.创建新的 密钥/公钥,并指定密钥名称,比如id_rsa_x(x为任意名称)

    ssh-keygen -t rsa -f ~/.ssh/id_rsa_x -C "yourmail@xxx.com"
    

    操作完成后,该目录会多出 id_rsa_xid_rsa_x.pub 两个文件。

    3.在 ~/.ssh/ 文件夹下创建一个 config 文件

    $ touch config
    $ vim config
    

    编辑config文件,配置不同的仓库指向不同的密钥文件。

    # 第一个账号,默认使用的账号
    Host github.com
    HostName github.com
    User git
    IdentityFile ~/.ssh/id_rsa
    # 第二个账号
    Host second.github.com  # second为前缀名,可以任意设置
    HostName github.com  #//这里填你们公司的git网址即可
    User git
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/id_rsa_x

    原理分析
    1.ssh 客户端是通过类似 git@github.com:githubUserName/repName.git ** 的地址来识别使用本地的哪个私钥的,地址中的 User 是@前面的git, Host 是@后面的github.com
    2.如果所有账号的 User 和 Host 都为 git 和 github.com,那么就只能使用一个私钥。所以要对User 和 Host 进行配置,让每个账号使用自己的 Host,每个 Host 的域名做 CNAME 解析到 github.com,如上面配置中的Host second.github.com
    3.配置了别名之后,新的地址就是
    git@second.github.com:githubUserName/repName.git**(在添加远程仓库时使用)。
    这样 ssh 在连接时就可以区别不同的账号了。

    4.查看SSH 密钥的值,分别添加到对应的 GitHub 账户中

    $ cat id_rsa.pub
    $ cat id_rsa_x.pub
    

    把这两个值分别 copy 到 GitHub 账号中的 SSH keys 中保存。

    5.清空本地的 SSH 缓存,添加新的 SSH 密钥 到 SSH agent中

    $ ssh-add -D
    $ ssh-add id_rsa
    $ ssh-add id_rsa_x

    执行ssh-add时出现Could not open a connection to your authentication agent

    若执行ssh-add /path/to/xxx.pem是出现这个错误:Could not open a connection to your authentication agent,则先执行如下命令即可:

      ssh-agent bash

    最后确认一下新密钥已经添加成功

    $ ssh-add -l
    

    6.测试 ssh 链接

    ssh -T git@github.com
    ssh -T git@second.github.com
    # xxx! You’ve successfully authenticated, but GitHub does not provide bash access.
    # 出现上述提示,连接成功
    

    7.取消 git 全局用户名/邮箱的设置,设置独立的 用户名/邮箱

    # 取消全局 用户名/邮箱 配置
    $ git config --global --unset user.name
    $ git config --global --unset user.email
    # 进入项目文件夹,单独设置每个repo 用户名/邮箱
    $ git config user.email "xxxx@xx.com"
    $ git config user.name "xxxx"
    

    查看git项目的配置

    git config --list
    

    8.命令行进入项目目录,重建 origin (whatever 为相应项目地址)

    $ git remote rm origin
    # 远程仓库地址,注意Host名称
    $ git remote add origin git@second.github.com:githubUserName/repName.git
    $ git remote -v # 查看远程
    

    10.远程 push 测试
    首先在 GitHub 上新建一个名为 testProj 的远程仓库,然后再在本地建一个本地仓库。

    $ cd ~/documnts
    $ mkdir testProj
    

    1.进入 testProj 文件夹,创建 REDME.md文件
    2.初始化此文件夹为git
    3.添加并提交README.md到Git本地仓库
    4.添加远程仓库
    5.把README.md推送到远程仓库

    $ cd testProj
    $ echo "# ludilala.github.io" >> README.md
    $ git init
    $ git add README.md
    $ git commit -m "first commit"
    # 如果前面已添加远程连接,就无需再次添加
    $ git remote add origin https://github.com/ludilalaa/ludilala.github.io.git
    $ git push -u origin master


    参考:https://www.jianshu.com/p/f7f4142a1556




  • 相关阅读:
    【从小白到专家】收官!Istio技术实践之九:路由控制与灰度发布
    Kube-OVN 1.2.0发布,携手社区成员打造高性能容器网络
    Kubernetes最佳实践之腾讯云TKE 集群组建
    5大最新云原生镜像构建工具全解析,3个来自Google,你了解几个?
    【从小白到专家】 Istio专题之七:30分钟讲透Istio访问与控制
    后疫情时期传统企业的云原生之路将走向何方?第二期(2019-2020)云原生实践调研报告发布!
    使用Spring Security控制会话
    Spring Security – security none, filters none, access permitAll
    No bean named 'springSecurityFilterChain' is defined
    Unable to locate Spring NamespaceHandler for XML schema namespace
  • 原文地址:https://www.cnblogs.com/zhengyan/p/10728527.html
Copyright © 2020-2023  润新知