Git多个账户SSH配置

  使用SSH协议,您可以连接到远程服务器和服务并进行身份验证。使用SSH密钥,您可以在每次访问时无需提供用户名和个人访问令牌即可连接到GitHub。

  如果使用http协议,每次提交或拉取等与服务器交互时都要输入密码,感觉很麻烦。于是决定使用SSH协议,因为自己使用的是github或gitlee等,公司使用的是gitlab的私有域名,所以要用到多git账户的SSH配置。看了很多文档写的不是很详细,下面详细说一下重要步骤!(以下在Mac系统中进行测试)

一、检测已有SSH,如果已经有,考虑到不是最新的,可以删除掉重新配置下。
  1. 打开终端,输入ls -al ~/.ssh
riber@Ribers-Mac-mini ~ % ls -al ~/.ssh
total 64
drwx------   9 riber  staff   288  9  4 17:52 .
drwxr-xr-x+ 51 riber  staff  1632  9  6 10:35 ..
-rw-r--r--@  1 riber  staff  6148  9  4 17:50 .DS_Store
-rw-r--r--@  1 riber  staff   252  9  4 17:52 config
-rw-------@  1 riber  staff  3434  3 17 15:03 id_rsa
-rw-r--r--@  1 riber  staff   742  3 17 15:03 id_rsa.pub
-rw-------@  1 riber  staff  3381  9  2 18:20 id_rsa_gitlab
-rw-r--r--@  1 riber  staff   742  9  2 18:20 id_rsa_gitlab.pub
-rw-r--r--@  1 riber  staff   802  9  4 17:52 known_hosts
  1. 检查目录列表(/Users/you ),同时按住Shift+Cmmand+.显示隐藏文件,看看是否已经拥有公共 SSH 密钥。如果您没有现有的公钥和私钥对,则直接生成;有的话删除公钥和私钥对,重新生成。
二、生成一个新的SSH密钥
  1. 打开终端,输入ssh-keygen -t ed25519 -C "your_email@example.com",不支持Ed25519算法的遗留系统则输入ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
riber@Ribers-Mac-mini ~ % ssh-keygen -t ed25519 -C "xxx@qq.com"
Generating public/private ed25519 key pair.
  1. 看到这句话就已经开始生成,按照提示输入文件存储位置,一般在/Users/you/.ssh/目录下,如:.ssh/rsa_gitlab。输入秘钥密码,输入后回车,也可直接回车跳过密码。
  2. 如果看到The key's randomart image is:说明秘钥已经生成成功。
三、将生成的秘钥添加到ssh代理中
  1. 在后台启动ssh-agent,输入eval "$(ssh-agent -s)"
riber@Ribers-Mac-mini ~ % eval "$(ssh-agent -s)"
Agent pid 60218
  1. 配置多个SSH账户并且macOS Sierra 10.12.2以上,需要修改~/.ssh/config文件。输入open ~/.ssh/config,如果可以打开,则直接修改,提示没有创建新的文件touch ~/.ssh/config
  2. config文件添加内容。如果在生成密钥时输入了密码则将IgnoreUnknown UseKeychain替换为UseKeychain yes
Host github.com
  AddKeysToAgent yes
  IgnoreUnknown UseKeychain
  IdentityFile ~/.ssh/rsa_github

Host:git 服务器域名
AddKeysToAgent:是否将秘钥添加到ssh代理中
IdentityFile:私钥文件名

  1. 将SSH私钥添加到ssh代理中,并将密码存储在钥匙串中。输入ssh-add -K ~/.ssh/rsa_gitlab
    这时可能会有警告:
WARNING: The -K and -A flags are deprecated and have been replaced
         by the --apple-use-keychain and --apple-load-keychain
         flags, respectively.  To suppress this warning, set the
         environment variable APPLE_SSH_ADD_BEHAVIOR as described in
         the ssh-add(1) manual page.

此时可用ssh-add --apple-use-keychain ~/.ssh/rsa_gitlab替换

四、将秘钥的公钥添加到github等git服务器中
  1. 拷贝公钥文件里的内容,输入pbcopy < ~/.ssh/rsa_gitlab.pub,在账户设置SSH配置中添加拷贝的内容,标题可以设置为电脑型号或名称。
  2. 测试连接是否正常,如果不正常请按步骤排查。输入ssh -T git@github.com。此时会让你输入yes或no是否继续连接,输入yes即可。如果看到以下输出就成功了。
Hi RiberWang! You've successfully authenticated, but GitHub does not provide shell access.

gitlab公司私有git

Warning: Permanently added '36.99.141.64' (ECDSA) to the list of known hosts.
Welcome to GitLab, wangrb!

最终config文件内容为:

Host github.com
  AddKeysToAgent yes
  IgnoreUnknown UseKeychain
  IdentityFile ~/.ssh/rsa_github

Host 36.99.141.64
  AddKeysToAgent yes
  # Port 8888
  IgnoreUnknown UseKeychain
  IdentityFile ~/.ssh/rsa_gitlab

最终ssh文件中包含文件为
ssh文件夹

总结:公司的私有域名不需要添加端口号,否则不会正常工作。生成SSH秘钥,将其添加到SSH代理和git账户设置中。

参考文档:github关于SSH的文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 首先,需要准备好对Git的全局用户进行配置。在初次安装Git时,往往会使用如下的命令配置全局用户名和邮箱: git...
    GorgeousXie阅读 6,526评论 0 5
  • 场景描述 对于程序员来说,我们会经常讲代码上传托管到GitHub等代码平台上。然而一般情况下,同一台电脑Git智能...
    静水红阳阅读 6,293评论 0 2
  • 应用场景 我们经常将代码托管到github、gitlab这样的网站上。为了避免每次push代码时都要输入用户名和密...
    程序员不止是程序猿阅读 3,785评论 0 0
  • 一 应用场景 我们经常将代码托管到github、gitlab这样的网站上。为了避免每次push代码时都要输入用户名...
    iYeso阅读 3,443评论 0 1
  • 唠叨几句 对于大多数程序员,喜欢将代码托管到github、gitlab、gitee上。为了避免每次push、pul...
    Balopy阅读 10,893评论 2 7

友情链接更多精彩内容