我正在尝试使用Gitlab CI / CD,并且为了运行测试并在生产服务器上部署代码,最终提出了以下.gitlab.ci.yml
生产服务器是简单的Ubuntu服务器
这是不好的做法,我该如何改进?
stages:
- testing
- deploying
image: php:latest
services:
- mysql:latest
variables:
MYSQL_DATABASE: project_name
MYSQL_ROOT_PASSWORD: secret
cache:
paths:
- vendor/
- node_modules/
before_script:
- apt-get update -yqq
- apt-get install gnupg -yqq
- curl -sL https://deb.nodesource.com/setup_8.x | bash -
- apt-get install git nodejs libcurl4-gnutls-dev libicu-dev libmcrypt-dev libvpx-dev libjpeg-dev libpng-dev libxpm-dev zlib1g-dev libfreetype6-dev libxml2-dev libexpat1-dev libbz2-dev libgmp3-dev libldap2-dev unixodbc-dev libpq-dev libsqlite3-dev libaspell-dev libsnmp-dev libpcre3-dev libtidy-dev libonig-dev libzip-dev -yqq
- docker-php-ext-install mbstring pdo_mysql curl json intl gd xml zip bz2 opcache
- pecl install xdebug
- docker-php-ext-enable xdebug
- curl -sS https://getcomposer.org/installer | php
- php composer.phar install
- cp .env.testing .env
- php artisan key:generate
- php artisan config:cache
- php artisan migrate
- php artisan db:seed
- 'which ssh-agent || ( apt-get install -qq openssh-client )'
- eval $(ssh-agent -s)
- ssh-add <(echo "$SSH_PRIVATE_KEY")
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
test:
stage: testing
script:
- php vendor/bin/phpunit --coverage-text --colors=never
deploy:
stage: deploying
script:
- php artisan deploy
我认为这不是一个坏习惯。但您可以使用jenkin