代理密钥 RSA SHA256:...返回不正确的签名类型

Nat*_*ram 3 git go circleci circleci-2.0

我正在尝试在 GitHub 上的 Go 项目上使用 CircleCI,并使用 Go 项目的默认模板。

作为参考,这里是默认的.circleci/config.yml 样子

version: 2
jobs:
  build:
    docker:
      - image: circleci/golang:1.12.7-buster
    working_directory: /go/src/github.com/Permaweb/Host
    steps:
      - checkout
      - run: go get -t -u -v ./...
      - run: go test -v ./...
Run Code Online (Sandbox Code Playgroud)

当作业运行时,我收到一个与代码本身完全无关的错误。

agent key RSA SHA256:L1iUIhjfKejEONe0TFU3TaWkNwE2O0xWF/09K7P8WnA returned incorrect signature type
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details.

    git pull <remote> <branch>

If you wish to set tracking information for this branch you can do so with:

    git branch --set-upstream-to=origin/<branch> develop
Run Code Online (Sandbox Code Playgroud)

该错误发生在git pullmaster.

我怎样才能解决这个问题?

bk2*_*204 6

这里有两个问题,它们是分开的和独立的。

“代理密钥返回不正确的签名类型”警告意味着正在使用的 SSH 代理返回无效数据。

当您使用 RSA SSH 密钥时,您可以使用以下几种哈希算法之一进行签名:SHA-1、SHA-256 或 SHA-512。最初,仅支持 SHA-1,因此每次使用 RSA 密钥都意味着您正在使用 SHA-1。但是,SHA-1 很弱,因此添加了额外的、更强大的哈希算法。

此消息表示 SSH 连接使用具有不同签名算法(SHA-256 或 SHA-512)的 RSA 密钥协商连接。但是,当被要求为该连接进行签名时,SSH 代理提供了一个不符合代理协议的 SHA-1 签名。

此消息本质上并不致命,但如果远程端不支持 SHA-1 签名,则它可能会选择拒绝您的连接。

您看到的另一条消息,来自 Git 的消息,意味着您正在尝试执行git pull命令,而没有为该分支设置远程。在这种情况下,这是因为您在go get现有存储库上使用,因为该命令将尝试更新现有存储库。

如果您只想安装依赖项,运行go build通常会自动为您安装,因此无需go get专门为此目的运行。如果你需要更复杂的东西,那么你应该使用 Git 本身,因为go get它不是为在复杂情况下使用而设计的。

  • 值得补充的是,阻止“代理密钥返回不正确的签名类型”消息的方法是将代理升级到支持 SHA-1 以外的签名算法的版本。请参阅https://superuser.com/a/1499705/287985 (4认同)