неверный формат ключа SSH gitlab-ci - PullRequest
0 голосов
/ 31 августа 2018

Я хотел бы запустить сценарий развертывания с помощью gitlab-ci, но шаг ssh-add $SSH_PRIVATE_KEY возвращает ошибку:

echo "$SSH_PRIVATE_KEY" | ssh-add -
Error loading key "(stdin)": invalid format

Можете посмотреть мои .gitlab-ci.yml:

deploy:
  image: node:9.11.1-alpine
  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

В настройках моего проекта я добавил переменную SSH_PRIVATE_KEY с id_rsa с моего рабочего сервера cat ~/.ssh/id_rsa.pub.

Кто-нибудь может мне помочь?

Ответы [ 2 ]

0 голосов
/ 24 июня 2019

По умолчанию это открытый ключ SSH в ~ / .ssh / id_rsa.pub.

Закрытый ключ содержится в ~ / .ssh / id_rsa

0 голосов
/ 17 июня 2019

В моем случае это произошло потому, что я сделал SSH_PRIVATE_KEY защищенной . Когда я отключил защищенное состояние, оно работало без ошибок.

enter image description here

...