您的位置:时时app平台注册网站 > 时时app平台注册网站 > Windows下配置多个git账号的SSH Key

Windows下配置多个git账号的SSH Key

2019-10-11 01:55

把公钥加进去,保存 退出

1.4 第四个 SSH Key 的生成

git bash 中输入以下命令,生成 gitee-user2 的密钥,注意第四个 SSH Key 不能再使用默认的文件名 id_rsa ,否则会覆盖之前的密钥文件:

ssh-keygen -t rsa -f ~/.ssh/id_rsa_gitee_two -C "gitee-user2@email.com"

在当前用户目录的 .ssh 目录下会生成 id_rsa_gitee_two 私钥文件和 id_rsa_gitee_two.pub 公钥文件,将 id_rsa_gitee_two.pub 公钥中的内容添加至 gitee-user2 的 Gitee 云端中。

部署开始

首先 先在自己的当前主机打开git bash

2.2 终端测试SSH Key

通过终端测试SSH Key是否生效,分别输入以下命令:

ssh -T git@github.com
ssh -T git@gitee.com
ssh -T git@two.github.com
ssh -T git@two.gitee.com

云服务器为:腾讯云
客户端:win10操作系统

git是一个分布式的版本控制系统。这也就意味着主机克隆原始仓库之后,每一个主机上的仓库都是相同并且完整的,没有主次之分。这样极大的保证了数据的安全性。

 

1.5 测试生成的 SSH Key

ssh密钥正确生成并且都把公钥部署云端完成,可以分别测试ssh密钥的连接是否有效,使用以下这些命令测试:

# 第二个SSH Key测试
ssh -T git@gitee.com -i ~/.ssh/id_rsa_gitee_one
# 连接成功提示
# Welcome to Gitee.com, gitee-user1!

# 第三个SSH Key测试
ssh -T git@github.com -i ~/.ssh/id_rsa_github_two
# 连接成功提示
# Hi github-user2! You've successfully authenticated, but GitHub does not provide shell access.

# 第四个SSH Key测试
ssh -T git@gitee.com -i ~/.ssh/id_rsa_gitee_two
# 连接成功提示
# Welcome to Gitee.com, gitee-user2!

也可以使用 ssh agent 添加密钥后进行测试,系统默认只读取id_rsa,为了让 ssh 识别新的密钥,使用 ssh-agent 手动添加私钥:

# 查看系统ssh-key代理
ssh-add -l
# Could not open a connection to your authentication agent.

# 如果发现上面的提示,说明系统代理里没有任何key,执行如下操作
exec ssh-agent bash

# 如果系统已经有ssh-key代理 ,执行下面的命令可以删除
ssh-agent -D

# 添加密钥到ssh-agent
ssh-add ~/.ssh/id_rsa_gitee_one
ssh-add ~/.ssh/id_rsa_gitee_two
ssh-add ~/.ssh/id_rsa_github_two

注明: ssh-agent 代理的局限,仅限当前窗口有效,打开新的窗口则ssh连接失效

1.服务端部署

  • 在云服务器上安装git服务程序
    yum install git
  • 添加一个用户git,只能用来上传文本文件,而不能ssh登录
    adduser git
    chsh -s $(command -v git-shell) git//使用git-shell替换bash,这样git用户就不能通过ssh登录
  • 创建git版本仓库,一般规范的方式要以.git为后缀:
    mkdir kingwen.git
  • 修改git版本仓库的所有者与所有组:
    chown -Rf git:git kingwen.git/ //这一步是让目录可以被git用户修改,否则会出现“ permission denied”错误
  • 初始化git版本仓库:
    cd kingwen.git/
    git --bare init

至此Git服务器部署好了,但是还不能够上传文档文件,也不能克隆你的仓库。需要在服务器上开放至少一种支持Git的协议(http/https/ssh),我们采用ssh

  • 添加ssh公钥,在/home/git/.ssh/authorized_keys里添加客户端的公钥,一行一个。如果没有文件,可以新建
    mkdir /home/git/.ssh
    touch /home/git/.ssh/authorized_keys

    在这一步放入公钥指的是客户端的公钥,所以涉及到客户端生成公钥:
    客户端如何生成公钥呢?首先我们明确客户端是也需要git服务程序的,我们用git服务程序来生成公钥就可以啦。

    需在客户端操作
    • 安装git (windows上都是点击下一步安装的) git官网
    • 打开git-bash,执行
    $ cd ~  #保证当前路径在”~”下
    $ ssh-keygen -t rsa -C "xxxxxx@yy.com"  #建议填写自己真实有效的邮箱地址
    

    *本机已完成ssh key设置,公钥存放路径为:c:/Users/{用户名}/.ssh/id_rsa.pub

 

1.1 第一个 SSH Key 的生成

打开 git bash,输入以下命令生成 github-user1 的 SSH Key:

ssh-keygen -t rsa -C "github-user1@email.com"

第一个 ssh key 使用默认名字,三下回车,完成第一个默认的 ssh key。

在当前用户目录的 .ssh 目录下会生成 id_rsa 私钥文件和 id_rsa.pub 公钥文件,将 id_rsa.pub 公钥中的内容添加至 github-user1 的 GitHub 云端中。

然后在 git bash 中输入以下命令测试该用户的 SSH 密钥是否有效:

ssh -T git@github.com

若连接成功则提示

Hi github-user1! You've successfully authenticated, but GitHub does not provide shell access.

ssh -T git@github.com
注明:该命令仅限于文件名为默认 id_rsa 的密钥

2.客户端部署

  • 配置账户
    $ git config --global user.name “your_username” #设置用户名
    $ git config --global user.email “your_registered_Email” #设置邮箱地址
  • 切换到某个目录来克隆仓库:eg:桌面
    cd ~/Desktop/
    git clone ssh://git@{服务器对外ip}:22/git/kingwen.git
  • 向Git版本仓库中提交一个新文件并提交到本地git仓库:
    echo "I successfully cloned the Git repository" > readme.txt
    git add readme.txt //添加进暂存区
    git status //查看状态
  • 推送到远程Git服务器,首先定义远程的Git服务器:
    git remote add server git@{服务器对外ip}:/root/kingwen.git
  • 将文件提交到远程Git服务器
    git push -u server master

打开你远端服务器的terminal 或者用git bash连接

1.3 第三个 SSH Key 的生成

git bash 中输入以下命令,生成 github-user2 的密钥,注意第三个 SSH Key 同样不能再使用默认的文件名 id_rsa ,否则会覆盖之前的密钥文件:

ssh-keygen -t rsa -f ~/.ssh/id_rsa_github_two -C "github-user2@email.com"

在当前用户目录的 .ssh 目录下会生成 id_rsa_github_two 私钥文件和 id_rsa_github_two.pub 公钥文件,将 id_rsa_github_two.pub 公钥中的内容添加至 github-user2 的 GitHub 云端中。

cat ~/.ssh/id_rsa.pub

3.2 同域的远程仓库地址需修改

把同域的第二个账号推送的远程仓库地址修改为不冲突的域,相关命令如下:

# github.com域
git remote rm origin
git remote add origin git@two.github.com:github-user2/text.git

# gitee.com域
git remote rm origin
git remote add origin git@two.gitee.com:gitee-user2/text.git

(2018-04-04)

然后用你主机连接即可

1.2 第二个 SSH Key 的生成

git bash 中输入以下命令,生成 gitee-user1 的密钥,注意第二个 SSH Key 不能再使用默认的文件名 id_rsa,否则会覆盖之前的密钥文件:

ssh-keygen -t rsa -f ~/.ssh/id_rsa_gitee_one -C "gitee-user1@email.com"

在当前用户目录的 .ssh 目录下会生成 id_rsa_gitee_one 私钥文件和 id_rsa_gitee_one.pub 公钥文件,将 id_rsa_gitee_one.pub 公钥中的内容添加至 gitee-user1 的 Gitee 云端中。

查看生成好的公钥,并复制好

2. 配置config文件

 

1. 生成并部署 SSH Key

ssh-keygen 生成密钥对 (默认就好,我自己是一直摁着回车的)

3. 项目仓库测试SSH Key

vim ~/.ssh/authorized_keys

本文记录生成同域的多个 git账号的 ssh key 和不同域的多个 ssh key。

3.1 为各仓库配置用户名和邮箱

分别在各仓库下配置相应的用户名和邮箱

git config user.name "username"
git config user.email "username@email.com"

2.1 编辑config文件

在 .ssh 目录下创建一个 config 文本文件,每个账号配置一个Host节点,主要配置项说明:

Host         # 主机别名
HostName     # 服务器真实地址
IdentityFile # 私钥文件路径
PreferredAuthentications # 认证方式
User         # 用户名

config 文件内容:

# ~/.ssh/config 配置多个git的ssh-key
# 第一个默认的SSH Key
Host github.com
    HostName github.com
    IdentityFile C:\Users\Administrator\.ssh\id_rsa
    PreferredAuthentications publickey

# 第二个SSH Key
Host gitee.com
    HostName gitee.com
    IdentityFile C:\Users\Administrator\.ssh\id_rsa_gitee_one
    PreferredAuthentications publickey

# 第三个SSH Key
Host two.github.com
    HostName github.com
    IdentityFile C:\Users\Administrator\.ssh\id_rsa_github_two
    PreferredAuthentications publickey

# 第四个SSH Key
Host two.gitee.com
    HostName gitee.com
    IdentityFile C:\Users\Administrator\.ssh\id_rsa_gitee_two
    PreferredAuthentications publickey

本文由时时app平台注册网站发布于时时app平台注册网站,转载请注明出处:Windows下配置多个git账号的SSH Key

关键词: