自2天以来,我一直在解决这个问题。
尝试使用我的生产服务器中的id_rsa.pub和id_rsa,仍然出现相同的错误... SSH_PRIVATE_KEY是我在GitLab的CI / CD设置中创建的变量。
编辑:不受保护,未被屏蔽。
# This file is a template, and might need editing before it works on your project.
# Official framework image. Look for the different tagged releases at:
# https://hub.docker.com/r/library/node/tags/
image: node:alpine
stages:
- deploy
deploy:
stage: deploy
before_script:
# Install ssh-agent if not already installed, it is required by Docker.
# (change apt-get to yum if you use a CentOS-based image)
- 'which ssh-agent || ( apk add --update openssh )'
# Add bash
- apk add --update bash
# Add git
- apk add --update git
# Run ssh-agent (inside the build environment)
- eval $(ssh-agent -s)
# Add the SSH key stored in SSH_PRIVATE_KEY variable to the agent store
- echo "$SSH_PRIVATE_KEY"
- echo "$SSH_PRIVATE_KEY" | ssh-add -
# For Docker builds disable host key checking. Be aware that by adding that
# you are suspectible to man-in-the-middle attacks.
# WARNING: Use this only with the Docker executor, if you use it with shell
# you will overwrite your user's SSH config.
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
# In order to properly check the server's host key, assuming you created the
# SSH_SERVER_HOSTKEYS variable previously, uncomment the following two lines
# instead.
# - mkdir -p ~/.ssh
# - '[[ -f /.dockerenv ]] && echo "$SSH_SERVER_HOSTKEYS" > ~/.ssh/known_hosts'
script:
- npm i -g pm2
- pm2 deploy ecosystem.config.js production
only:
- master
当我运行管道时,仍然出现此错误...
$ echo "$SSH_PRIVATE_KEY" | ssh-add -
Error loading key "(stdin)": invalid format
能请你帮忙吗?我无助,无知,无望了...
非常感谢!
答案 0 :(得分:1)
就像其他任何人一样,我也遇到了同样的问题,但是却错过了END RSA PRIVATE KEY部分的最后一个破折号。显然,它必须有5个破折号作为分隔线。
答案 1 :(得分:-1)
SSH_PRIVATE_KEY是我在GitLab的CI / CD设置中创建的变量。
在“值”字段中粘贴您先前创建的私钥的内容。
因此,请确保您已粘贴id_rsa
的全部内容,包括-----BEGIN RSA PRIVATE KEY-----
和-----END RSA PRIVATE KEY-----
(最后5个-
)