这是我第一次访问GitHub,我没有使用控制台的经验。我在MacBook上使用Bash。当我尝试访问GitHub时,我得到了这个:

git clone git@github.com:dhulihan/league-of-legends-data-scraper.git
Cloning into 'league-of-legends-data-scraper'...
Permission denied (publickey).
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

我试着按照Github页面上关于拒绝许可的说明进行操作。

当我使用ssh -vT git@github.com时,我得到以下结果:

OpenSSH_6.2p2, OSSLShim 0.9.8r 8 Dec 2011
debug1: Reading configuration data /etc/ssh_config
debug1: /etc/ssh_config line 20: Applying options for *
debug1: Connecting to github.com [192.30.252.129] port 22.
debug1: Connection established.
debug1: identity file /Users/XXXX/.ssh/id_rsa type -1
debug1: identity file /Users/XXXX/.ssh/id_rsa-cert type -1
debug1: identity file /Users/XXXX/.ssh/id_dsa type -1
debug1: identity file /Users/XXXX/.ssh/id_dsa-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.2
debug1: Remote protocol version 2.0, remote software version libssh-0.6.0
debug1: no match: libssh-0.6.0
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-sha1 none
debug1: kex: client->server aes128-ctr hmac-sha1 none
debug1: sending SSH2_MSG_KEXDH_INIT
debug1: expecting SSH2_MSG_KEXDH_REPLY
debug1: Server host key: RSA 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48
debug1: Host 'github.com' is known and matches the RSA host key.
debug1: Found key in /Users/XXXX/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey
debug1: Next authentication method: publickey
debug1: Trying private key: /Users/XXXX/.ssh/id_rsa
debug1: Trying private key: /Users/XXXX/.ssh/id_dsa
debug1: No more authentication methods to try.
Permission denied (publickey).

接下来,eval "$(ssh-agent -s)"返回"Agent pid 2314", 但是ssh-add -l返回“代理没有身份”。

这就是我被困住的地方。


当前回答

有时检查~/.ssh/config可能很有用

应该是这样的

Host github.com
 IdentityFile ~/.ssh/id_rsa

如果链接不同的密钥,Id_rsa可能不同。

其他回答

详情请在此回答。

总而言之,当ssh-add -l返回“代理没有身份”时,这意味着ssh使用的密钥(存储在~/。ssh / id_rsa ~ /。Ssh /id_dsa等)要么丢失,Ssh -agent(身份验证代理)不知道它们,要么它们的权限设置不正确(例如,world writable)。

如果您的密钥丢失或没有生成任何密钥,请使用ssh-keygen -t rsa,然后ssh-add来添加密钥。

如果密钥存在,但ssh-agent不知道(比如密钥在非标准文件夹中),则使用ssh-add /path/to/my-non-standard-ssh-folder/id_rsa添加密钥。

如果您在ssh-add或ssh-agent上遇到问题,请参阅此答案。

试试这个:

ssh-add ~/.ssh/id_rsa

为我工作

我在从备份恢复硬盘驱动器后遇到了这个问题。

我的问题: 我可以检查和看到我的远程(使用git remote -v),但当我执行git push origin master时,它返回:Permission denied (publickey)。无法从远程存储库读取。

我已经有一个SSH文件夹和SSH密钥,并通过终端(SSH -add /path/to/my- SSH -folder/id_rsa)添加它们成功添加了我的身份,但我仍然无法推送,仍然得到相同的错误。生成一个新密钥对我来说是一个坏主意,因为它与AWS上其他非常安全的权限绑定在一起。

事实证明,密钥和我的Github个人资料之间的链接已经断开。

解决方案: 在配置文件>设置>中重新添加密钥到Github, SSH和GPG密钥解决了这个问题。

另外: 我的账户设置了双重认证。在这种情况下,如果终端请求凭据,使用您的用户名-而不是您的Github密码。对于2因素身份验证,您需要使用您的身份验证代码(对我来说,这是由我手机上的Authy生成的,我必须将其复制到终端的pw中)。

这可能导致任何新终端,代理id是不同的。 您需要为代理添加私钥

$ ssh-add <path to your private key>

这也适用于我: Chmod 700 .ssh Chmod 600 .ssh/id_rsa . exe Chmod 644 .ssh/id_rsa.pub

然后,输入ssh-add ~/.ssh/id_rsa