Не могу перенести db в laravel gitlab ci - PullRequest
0 голосов
/ 09 ноября 2019

У меня есть конфигурация для laravel с gitlab ci

Все будет хорошо, но когда он достигает 'Migrating Command', он терпит неудачу.

Это мой yaml:

image: php:latest

services:
  - mysql:latest

variables:
  MYSQL_ROOT_PASSWORD: root
  MYSQL_USER: homestead
  MYSQL_PASSWORD: secret
  MYSQL_DATABASE: homestead
  DB_HOST: mysql

stages:
  - test

cache:
  paths:
    - vendor/

test:
  stage: test
  before_script:
    - apt-get update -yqq
    - apt-get install gnupg -yqq
    - apt-get install git 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 -yqq libzip-dev
    - 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.example .env
    - php artisan key:generate
    - php artisan config:cache
    - php artisan migrate -v
  script:
    - php vendor/bin/phpunit --coverage-text --colors=never
  only:
    - master

Это ошибка, которую я получил:

Illuminate\Database\QueryException  : SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client (SQL: select * from information_schema.tables where table_schema = laravel and table_name = migrations and table_type = 'BASE TABLE')

1 Ответ

0 голосов
/ 09 ноября 2019

Я настоятельно рекомендую заменить mysql:latest изображение на mysql:5.7, поскольку MySQL 8 по умолчанию использует другой метод аутентификации .

Ваш файл yaml должен выглядеть примерно так:

image: php:latest

services:
  - mysql:5.7
# rest of your file
...