IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    生成 SSH 公钥及多账户设置

    admin发表于 2016-03-08 13:39:50
    love 0

    许多 Git 服务器都使用 SSH 公钥进行认证。
    为了向 Git 服务器提供 SSH 公钥,如果某系统用户尚未拥有密钥,必须事先为其生成一份。
    这个过程在所有操作系统上都是相似的。
    首先,你需要确认自己是否已经拥有密钥。
    默认情况下,用户的 SSH 密钥存储在其 ~/.ssh 目录下。

    $ cd ~/.ssh
    $ ls

    我们需要寻找一对以 id_dsa 或 id_rsa 命名的文件,其中一个带有 .pub 扩展名。 .pub 文件是你的公钥,另一个则是私钥。 如果找不到这样的文件(或者根本没有 .ssh 目录),你可以通过运行 ssh-keygen 程序来创建它们。在 Linux/Mac 系统中,ssh-keygen 随 SSH 软件包提供;在 Windows 上,该程序包含于 MSysGit 软件包中。

    首先 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

    可以针对不同的git生成各自的 ssh 公钥。
    进入 ~/.ssh 目录后,创建config文件,无扩展名,在里面设置配置项。
    config基本写法:

    Host myhost(这里是自定义的host简称,以后连接远程服务器就可以用命令ssh myhost)[注意下面有缩进]
       User 登录用户名(如:git)
       HostName 主机名可用ip也可以是域名(如:github.com或者bitbucket.org)
       Port 服务器open-ssh端口(默认:22,默认时一般不写此行)
       IdentityFile 证书文件路径(如~/.ssh/id_rsa_*)

    例如:

    host gitlab.iduoduo.com
     HostName gitlab.duoduo.com
     IdentityFile ~/.ssh/id_rsa
     User k68@duoduo.com
     
    host yiya-xueyu.rhcloud.com
     HostName yiya-xueyu.rhcloud.com
     IdentityFile ~/.ssh/id_rsa_rhcloud
     User k68@126.com

    © admin for 可乐吧, 2016. | Permalink | No comment | Add to del.icio.us
    Post tags: SSH 公钥, ssh 多账户

    Feed enhanced by Better Feed from Ozh



沪ICP备19023445号-2号
友情链接