在GitLab CI中添加SSH密钥时出现语法错误。

7
参考文献:https://gitlab.ida.liu.se/help/ci/ssh_keys/README.md 以下脚本存在问题。即使我将最后一个符号从`更改为',问题在于如何修复下面所示的错误: $ ssh-add <(echo "$SSH_PRIVATE_KEY") /bin/sh: eval: line 24: syntax error: unexpected "("

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 || ( apt-get update -y && apt-get install openssh-client -y )'

  # 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
  - ssh-add <(echo "$SSH_PRIVATE_KEY")

  # 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 /.dockerinit ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config`
2个回答

4
为了使其正常工作,我必须替换:
ssh-add <(echo "$SSH_PRIVATE_KEY")

带有:

printenv SSH_PRIVATE_KEY | ssh-add -

3
我已经尝试了很多次,下面的.gitlab-ci.yml应该可以正常工作。
    image: gitlab/dind:latest

variables:
  COMPOSE: docker-compose

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 || ( apt-get update -y && apt-get install openssh-client -y )'

  # 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
  - ssh-add <(echo "$SSH_PRIVATE_KEY")

  # 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

  - ssh-keyscan -H 'gitlab.com' >> ~/.ssh/known_hosts
  - ssh-keyscan gitlab.com | sort -u - ~/.ssh/known_hosts -o ~/.ssh/known_hosts

  - '[[ -f /.dockerinit ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'

stages:
  - build
  - test
  - deploy

# Add a job called 'build' -> to run your builds
# TODO: Build the image in remote docker registry 
build-dev:
  stage: build 
  script:
    - sh scripts/install-dev.sh
    - $COMPOSE build
  only:
    - dev 

build-master:
  stage: build 
  script:
    - sh scripts/install.sh
    - $COMPOSE build
  only:
    - master 

我还在这里开了一个问题


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接