先是 先在团结的脚下主机打开git bash

本文记录生成同域的三个 git账号的 ssh key 和差异域的多少个 ssh key。

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

git是二个分布式的版本控制系统。那也就意味着主机克隆原始仓库之后,每二个主机上的库房都以一致并且完全的,没有先后之分。这样庞大的保管了数量的安全性。

问题

在动用Git与tortoisegit的时候,钦命远程版本库的地点有2种方法:

  1. 利用https格局的git地址万分直白(
    bash依旧tortoisegit都能周密应用,不过每便须求三番五次远程服务器时,都要唤醒作者输入用户名与密码,格外愁肠;
  2. 运用ssh格局的git地址万分舒适(git@git.oschina.net:xxxx/xxx.git),不需求输入密码,不过须求安插。

率先种艺术没啥说的,第2种艺术的拔取,小编陈设的时候出现了1个难点:

安排了tortoisegit的putty后,直接用tortoisegit可以不输入密码直接完事操作;可是当自个儿动用git
bash的时候,使用git pull之类的一声令下还要求作者输入密码…

P.S. 别说作者闲的,有tortoisegit为什么还用git bash。实际上,使用git
bash在局地操作上恐怕挺方便的(比如删除分支 git push origin :branchx)。

 

那怎么弄才能让那贰个小孩都不输入密码吗?

此地又有三种办法…

  1. 调整tortoisegit的settings中的network选项,将tortoisegitplink.exe改成git安装目录的下bin\ssh.exe。若是原先用ssh-keygen.exe配置好了git下的ssh话,改完就能直接用,没布置好的话…等下说。
  2. 默许安装tortoisegit,会利用PuTTY(plink)作为默许的ssh格局,声称对windows集成更好,若是不想改那种措施的话,就只可以让git的ssh.exe使用PuTTY的密钥了,tortoisegit继续利用PuTTY。

专注:tortoisegit可以自行载入putty
key,使用puttygen程序可以扭转对应的公钥与私钥。

 

ssh-keygen 生成密钥对 (暗中认可就好,笔者自个儿是一贯摁着回车的)

1. 生成并布署 SSH Key

布署初阶

化解办法

本人原先曾经安插好了PuTTY,只是bash中的openssh不可以用,于是作者动用第两种办法。公钥是同等的,要求更换一下私钥。

固化putty的ppk文件,用puttygen(在tortoisegit目录里面)打开(conversions>import
key)

澳门金沙国际 1

接下来点击conversions>export openSSH
key,保存文件为id_rsa文件,不要拓展名。

澳门金沙国际 2

然后再点击下边的save public key按钮,保存为id_rsa.pub文件,效果如下:

澳门金沙国际 3

找到本身%home%下(【澳门金沙国际】远程访问服务器,Windows下安排三个git账号的SSH。~)的.ssh文件夹,一般windows
7未来的在c:\用户\“本人的用户名”上面。没有的话,可以新建。

把刚刚的八个文本扔进去。打开git bash,执行命令,如下图。

澳门金沙国际 4

跳转到本人的本子路径,执行git
pull,命令行再也不提示密码了…再尝试tortoisegit,照旧也不提拔要密码。

那般事实上相当于配置了三次git的ssh,让openSSH与putty使用相同的密钥,git
bash使用openssh连接,而tortoisegit使用PuTTY连接,何人也不碍着哪个人。

 

 

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 的密钥

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

实践指南

根据本身的喜好,为了不重复输入用户名与密码,可以接纳兼用PuTTY与OpenSSH恐怕只用openSSH

cat ~/.ssh/id_rsa.pub

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.客户端安插

  • 布署账户
    $ 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

*兼用openSSH与PuTTY*

1.配置tortoisegit的PuTTY:

2.认可tortoisegit可以健康使用PuTTY,可以遵从地点消除措施的步子配置openSSH以供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 云端中。

*只用openSSH*

1.使用git bash,输入ssh-keygen.exe –t rsa –C “自己的email”

2.比方不想输密码的话,一路回车,程序会自动生成.ssh/上边的id_rsa和对应的pub文件

3.打开id_rsa.pub文件,将内容全方位复制

4.在版本控制的网站(例如oschina),在个人资料里面,SSH公钥,新添三个公钥,将刚刚的事物贴进去。

5.足以参见拓展验证

6.调动tortoisegit的settings中的network选项,将tortoisegitplink.exe改成git安装目录的下bin\ssh.exe。

7.在相应档次的文本夹上右键,点击tortoisegit下的settings,定位到remote

8.改动对应的url为SSH地址,putty key定位到id_rsa文件,如下图

澳门金沙国际 5

9.测试tortoisegit,没有错误,则水到渠成~

 

 

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 云端中。

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

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连接失效

vim ~/.ssh/authorized_keys

2. 配置config文件

把公钥加进去,保存 退出

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

 

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

接下来用你主机连接即可

3. 档次仓库测试SSH Key

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

各自在各仓库下布置相应的用户名和邮箱

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

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)

相关文章