1

我正在尝试使用Deployer设置Gitlab CI/CD我的Symfony项目,但我无法做到。在我的管道上执行部署时,我有一个这意味着我的配置是错误的。Operation timed out error

我的 gitlab-ci.yml :

image: php:7.4-cli-alpine

stages:
  - deploy

before_script:
  - apk add --update git openssh-client
  - mkdir -p ~/.ssh && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config
  - eval $(ssh-agent -s)
  - echo "$SSH_PRIVATE_KEY" | ssh-add -

deploy:
  stage: deploy
  script:
    - curl --show-error --silent https://getcomposer.org/installer | php
    - php composer.phar install -d app/
    - app/vendor/bin/dep deploy dev -vvv
  environment:
    name: prod

我的 hosts.yml 库存:

dev-server.com:
  stage: dev
  hostname: XX.XXX.XX.X
  user: deployer
  branch: develop
  identityFile: ~/.ssh/gitlab
  deploy_path: /var/www/recruitment_back
  keep_releases: 1

我的 Gitlab 管道错误:

$ app/vendor/bin/dep deploy dev -vvv
✈︎ Deploying develop on XX.XXX.XX.X
• done on [dev-server.com]
➤ Executing task deploy:prepare
[dev-server.com] > export APP_ENV='prod'; echo $0
[dev-server.com] < ssh multiplexing initialization
[dev-server.com] < ssh: connect to host XX.XXX.XX.X port 22: Operation timed out
➤ Executing task deploy:failed
• done on [dev-server.com]
✔ Ok [0ms]

我还在设置中添加了变量SSH_PRIVATE_KEY,还在我的服务器上Gitlab CI/CD添加了我的公共 ssh 密钥。authorized_keys在我的本地机器上执行部署工作良好。

我的配置有什么问题?

4

1 回答 1

0

我的解决方案:

  1. 为 Gitlab CI 生成临时 ssh 密钥并添加PRIVATE_KEYGitlab 变量截屏
  2. 在我的 AWS EC2 服务器上生成 ssh 密钥并在 Gitlab 中添加公共 ssh 密钥以接受git cloneDeployer 执行的操作
  3. 通过执行命令在我的 AWS EC2 服务器上接受 gitlab 主机连接ssh-keyscan -t rsa gitlab.com >> ~/.ssh/known_hosts
  4. 确保您的 AWS EC2 服务器接受 gitlab 运行器的 ssh 连接。我已经接受了所有 ip 但有没有最好的解决方案?例如通过 gitlab IP 限制?

我的 gitlab-ci.yml:

image: php:7.4

stages:
  - deploy

before_script:
  - 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )'
  - eval $(ssh-agent -s)
  - ssh-add <(echo "$PRIVATE_KEY")
  - mkdir -p ~/.ssh
  - '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'

  - apt-get install -y curl git
  - curl -LO https://deployer.org/deployer.phar
  - mv deployer.phar /usr/local/bin/dep
  - chmod +x /usr/local/bin/dep

deploy:
  stage: deploy
  script:
    - dep deploy dev -vvv
  only:
    - develop

如果有更好的解决方案。请告诉我。

于 2020-09-21T22:36:23.333 回答