服务器上的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的/ MacOS的系统中。ssh-keygen随SSH软件包提供;在视窗上,该程序包含于MSysGit软件包中。

$ ssh-keygen -o
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 [email protected]

首先ssh-keygen会确认密钥的存储位置(默认为.ssh/id_rsa),然后它会要求你输入两次密码。如果你不想在使用密钥时输入密码,将其留空即可。然而,如果你使用了密码,那么请确保确保添加了-o选项,它会以比格式格式化更能抵抗暴力破解的格式保存私钥。你也可以用ssh-agent工具来避免每次都要输入密码。

现在,进行了上述操作的用户需要将各自的公钥发送给任意一个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== [email protected]

你可能感兴趣的:(服务器上的Git-生成SSH公钥)