【发布时间】:2011-07-16 11:27:56
【问题描述】:
我正在尝试在 linux 上设置一个 git 客户端。我将我的私钥上传到机器上,我知道我应该把它放在 ~/.ssh 中,但我无权访问那个文件夹。
我如何告诉 git 在其他地方寻找私钥?
【问题讨论】:
标签: git ssh private-key
我正在尝试在 linux 上设置一个 git 客户端。我将我的私钥上传到机器上,我知道我应该把它放在 ~/.ssh 中,但我无权访问那个文件夹。
我如何告诉 git 在其他地方寻找私钥?
【问题讨论】:
标签: git ssh private-key
您可以使用ssh config file 来实现。
首先在您的~/.ssh 文件夹中创建一个名为config 的文件,您可以使用如下命令
$ nano ~/.ssh/config
然后,文件的内容应该具有基于每个主机名的密钥的位置。例如:
Host github.com
IdentityFile ~/myPublicKeyFolder/myGitHubFile
Host heroku.com
IdentityFile ~/myPublicKeyFolder/myHerokuFile
因此,当 git 尝试访问每个主机时,它将根据您尝试访问的 git 主机遵循此配置文件中的规则
【讨论】:
一种选择是使用ssh-agent 并向ssh-add 提供文件名。
例如:
$ ssh-agent /bin/bash
$ ssh-add ~/mykeys/id_rsa
【讨论】:
我会说将文件名放入~/.ssh/config,但您也可能无权访问此文件。
您可以为ssh 提供与-i keyfile 选项一起使用的私钥。
现在怎么说 git 将哪些选项传递给 ssh?
GitTips page 表示创建一个包装脚本并使用GIT_SSH 环境变量指向它。
看起来你也可以使用 git 配置 core.gitProxy,但我没有找到一个很好的例子,some mailing list message 建议它仅适用于 git: 协议。
【讨论】:
使用 ssh 代理
ssh-agent bash -c 'ssh-add /home/me/my_private_key; git clone git@bitbucket.org:uname/test-git-repo.git'
【讨论】:
对于我正在开发我的应用程序的项目,我需要输出一个带有所有 git 命令的 shell 脚本来初始化/提交/推送到外部存储库。 ~/.ssh/config 不受限制,所以我的应用程序目录中有我的公钥/私钥。我使用了 vhallac 的答案。这是我必须在我的 shell 脚本中执行的操作才能使用我的密钥:
eval `/usr/bin/ssh-agent`
ssh-add /path/to/.ssh/id_rsa
希望这对某人有所帮助
【讨论】: