服务器上的 Git - 生成 SSH 公钥
来源:互联网 发布:淘宝怎么骗运费险 编辑:程序博客网 时间:2024/05/17 21:51
https://git-scm.com/book/zh/ch4-3.html
4.3 服务器上的 Git - 生成 SSH 公钥
生成 SSH 公钥
如前所述,许多 Git 服务器都使用 SSH 公钥进行认证。 为了向 Git 服务器提供 SSH 公钥,如果某系统用户尚未拥有密钥,必须事先为其生成一份。 这个过程在所有操作系统上都是相似的。 首先,你需要确认自己是否已经拥有密钥。 默认情况下,用户的 SSH 密钥存储在其~/.ssh 目录下。 进入该目录并列出其中内容,你便可以快速确认自己是否已拥有密钥:
$ cd ~/.ssh
$ ls
authorized_keys2 id_dsa known_hosts
config id_dsa.pub
我们需要寻找一对以 id_dsa 或id_rsa 命名的文件,其中一个带有 .pub 扩展名。.pub 文件是你的公钥,另一个则是私钥。 如果找不到这样的文件(或者根本没有.ssh 目录),你可以通过运行 ssh-keygen 程序来创建它们。在 Linux/Mac 系统中,ssh-keygen 随 SSH 软件包提供;在 Windows 上,该程序包含于 MSysGit 软件包中。
$ ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/home/schacon/.ssh/id_rsa):
Created directory '/home/schacon/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/schacon/.ssh/id_rsa.
Your public key has been saved in /home/schacon/.ssh/id_rsa.pub.
The key fingerprint is:
d0:82:24:8e:d7:f1:bb:9b:33:53:96:93:49:da:9b:e3 schacon@mylaptop.local
首先 ssh-keygen 会确认密钥的存储位置(默认是.ssh/id_rsa),然后它会要求你输入两次密钥口令。如果你不想在使用密钥时输入口令,将其留空即可。
现在,进行了上述操作的用户需要将各自的公钥发送给任意一个 Git 服务器管理员(假设服务器正在使用基于公钥的 SSH 验证设置)。 他们所要做的就是复制各自的.pub 文件内容,并将其通过邮件发送。 公钥看起来是这样的:
$ cat ~/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAklOUpkDHrfHY17SbrmTIpNLTGK9Tjom/BWDSU
GPl+nafzlHDTYW7hdI4yZ5ew18JH4JW9jbhUFrviQzM7xlELEVf4h9lFX5QVkbPppSwg0cda3
Pbv7kOdJ/MTyBlWXFCR+HAo3FXRitBqxiX1nKhXpHAZsMciLq8V6RjsNAQwdsdMFvSlVK/7XA
t3FaoJoAsncM1Q9x5+3V0Ww68/eIFmb1zuUFljQJKprrX88XypNDvjYNby6vw/Pb0rwert/En
mZ+AW4OZPnTPI89ZPmVMLuayrD2cE86Z/il8b+gw3r3+1nKatmIkjn2so1d01QraTlMqVSsbx
NrRFi9wrf+M7Q== schacon@mylaptop.local
关于在多种操作系统中生成 SSH 密钥的更深入教程,请参阅 GitHub 的 SSH 密钥指南 https://help.github.com/articles/generating-ssh-keys。
https://segmentfault.com/a/1190000002645623#articleHeader0
1、设置Git的user name和email:(如果是第一次的话)
$ git config --global user.name"humingx"
$ git config --global user.email"humingx@yeah.net"
2、生成密钥
$ ssh-keygen -t rsa -C"humingx@yeah.net"
连续3个回车。如果不需要密码的话。
最后得到了两个文件:id_rsa和id_rsa.pub。
如果不是第一次,就选择overwrite.
3、添加密钥到ssh-agent
确保 ssh-agent 是可用的。ssh-agent是一种控制用来保存公钥身份验证所使用的私钥的程序,其实ssh-agent就是一个密钥管理器,运行ssh-agent以后,使用ssh-add将私钥交给ssh-agent保管,其他程序需要身份验证的时候可以将验证申请交给ssh-agent来完成整个认证过程。
# start the ssh-agent in the background
eval"$(ssh-agent -s)"
Agent pid 59566
添加生成的 SSH key 到 ssh-agent。
$ ssh-add ~/.ssh/id_rsa
4、登陆Github, 添加 ssh 。
把id_rsa.pub文件里的内容复制到这里
5、测试:
$ ssh -T git@github.com
你将会看到:
The authenticity of host'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?
选择 yes
Hi humingx! You've successfully authenticated, but GitHub does not provide shell access.
如果看到Hi后面是你的用户名,就说明成功了。
6、修改.git文件夹下config中的url。
修改前
[remote "origin"]
url = https://github.com/humingx/humingx.github.io.git
fetch = +refs/heads/*:refs/remotes/origin/*
修改后
[remote "origin"]
url = git@github.com:humingx/humingx.github.io.git
fetch = +refs/heads/*:refs/remotes/origin/*
7、发布
- 服务器上的 Git - 生成 SSH 公钥
- 服务器上的 Git - 生成 SSH 公钥
- 服务器上的 Git - 生成 SSH 公钥
- 服务器上的 Git - 生成 SSH 公钥
- 4.3 服务器上的 Git - 生成 SSH 公钥
- 4.3 服务器上的 Git - 生成 SSH 公钥
- 第四章 服务器上的git协议和生成SSH公钥
- Git-生成SSH公钥
- Git - 生成SSH公钥
- Git生成 SSH 公钥
- Git生成ssh公钥
- Git 生成SSH 公钥
- Git | 生成SSH公钥
- Git 服务器SSH公钥
- Git服务器 - ssh公钥
- 快速在linux上搭建基于git+ssh的服务器
- Git ssh key的生成
- ubuntu上开启ssh服务,并搭建基于ssh的git服务器
- c++ utility头文件
- 第15周实践项目1.1-阅读程序,体会STL用法
- Oracle osw启动参数一大坑说明(Redhat Linux 6.5 x64)
- CGAL【1】实现Hole Filling(补洞)功能
- linux下如何部署(执行)java jar包,并关闭此jar的进程
- 服务器上的 Git - 生成 SSH 公钥
- Python Dictionary详解
- 子元素浮动父容器高度不能自适应的CSS解决方法
- 理解RESTful架构
- 关于2C与2B的产品经理,这可能是最真诚的一篇分享了
- 卷积神经网络(CNN)讲解及代码
- java实现文件夹移动
- PAT天梯赛练习题——L3-003. 社交集群(并查集按秩合并)
- Java中如何遍历Map对象的4种方法