gpt4 book ai didi

mysql - Gitlab CI 黄昏 - MySQL 连接被拒绝

转载 作者:可可西里 更新时间:2023-11-01 08:23:38 25 4
gpt4 key购买 nike

这个问题现在已经被问过好几次了,但我尝试了所有的解决方案,我发现并有一个运行“正常”的 PHPUnit 测试,具有类似的设置,所以我所做的一切都不会是错误的。

问题来了:
我知道这个问题与 Gitlab CI 和 docker 结合使用的主要原因(仅报告?)使用了错误的主机。几乎在每种情况下,OP 都会尝试使用某种本地主机来访问数据库。
这不可能是这种情况,因为 DB_HOST 在我的 variables 中,DB_HOST 在我的 .env 文件中,并且我的 mysql 服务的别名都是一样的。

我什至连接到容器(通过在 dusk 命令之前添加 sleep 1h 并执行 docker exec)并成功登录到我的数据库并看到迁移和种子表。 Tinker 也有锻炼。
唯一的问题是黄昏。
有趣的事实:转储我的 DB_HOST 得到 mysql-test(我在运行 dusk 之前做了一个 config:clear,甚至将它添加到我的 设置函数。

我的想法真的用完了,我希望能从人群中得到一些想法。

这是我的 .yml 文件

stages:
- build
- test

variables:
DB_HOST: mysql-test
MYSQL_DATABASE: laravel
MYSQL_ROOT_PASSWORD: secret
DB_CONNECTION: mysql

composer:
image: lorisleiva/laravel-docker:latest
stage: build
script:
- composer install --no-progress --no-interaction
- cp .env.gitlab-testing .env
- php artisan key:generate
artifacts:
paths:
- vendor/
- bootstrap/
- .env
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- vendor/
tags:
- docker

npm:
image: lorisleiva/laravel-docker:latest
stage: build
script:
- npm install
- npm run prod
artifacts:
paths:
- public/mix-manifest.json
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- node_modules/
tags:
- docker

dusk:
stage: test
dependencies:
- composer
- npm
tags:
- docker
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- vendor
- node_modules
policy: pull

services:
- name: mysql:5.7
alias: mysql-test

image: chilio/laravel-dusk-ci:latest
script:
- cp .env.dusk.gitlab-testing .env
- cp phpunit.dusk.xml phpunit.xml
- configure-laravel
- start-nginx-ci-project
- php artisan dusk --colors --debug

artifacts:
paths:
- ./storage/logs
- ./tests/Browser/screenshots
- ./tests/Browser/console
expire_in: 7 days
when: always

.env.dusk.gitlab-testing

APP_ENV=local
APP_KEY=
APP_DEBUG=true
APP_LOG_LEVEL=debug
APP_URL=http://localhost

LOG_CHANNEL=stack
HEADLESS=true

DB_CONNECTION=mysql
DB_HOST=mysql-test
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=secret

BROADCAST_DRIVER=log
CACHE_DRIVER=array
SESSION_DRIVER=array
QUEUE_DRIVER=sync

phpunit.dusk.xml

<?xml version="1.0" encoding="UTF-8"?>
<phpunit backupGlobals="false"
backupStaticAttributes="false"
bootstrap="vendor/autoload.php"
colors="true"
convertErrorsToExceptions="true"
convertNoticesToExceptions="true"
convertWarningsToExceptions="true"
processIsolation="false"
stopOnFailure="false">
<testsuites>
<testsuite name="Browser Tests">
<directory suffix="Test.php">./tests/Browser</directory>
</testsuite>
</testsuites>
<filter>
<whitelist processUncoveredFilesFromWhitelist="true">
<directory suffix=".php">./app</directory>
</whitelist>
</filter>
<php>
<env name="APP_ENV" value="local"/>
<env name="CACHE_DRIVER" value="array"/>
<env name="SESSION_DRIVER" value="array"/>
<env name="QUEUE_DRIVER" value="sync"/>
</php>
</phpunit>

最佳答案

现在确实有效。
这是我的文件现在的样子:
.env.dusk.gitlab-测试:

APP_ENV=local
APP_KEY=base64:WY4y4XWUAKbCPzf8XqC92z5wWMn7oOHXZMFMbg9al3E=
APP_DEBUG=true
APP_LOG_LEVEL=debug
APP_URL=http://localhost

LOG_CHANNEL=stack

DB_CONNECTION=mysql
DB_HOST=mysql-test
DB_DATABASE=laravel
DB_USERNAME=laravel
DB_PASSWORD=secret

BROADCAST_DRIVER=log
CACHE_DRIVER=array
SESSION_DRIVER=array
QUEUE_DRIVER=sync

.gitlab-ci.yml

stages:
- build
- test
- deploy

# Variables
variables:
DB_HOST: mysql-test
MYSQL_DATABASE: laravel
MYSQL_USER: laravel
MYSQL_PASSWORD: secret
MYSQL_ROOT_PASSWORD: secretroot
DB_CONNECTION: mysql

composer:
image: lorisleiva/laravel-docker:latest
stage: build
script:
- cp .env.gitlab-testing .env
- composer install --no-progress --no-interaction
- php artisan key:generate
artifacts:
paths:
- vendor/
- bootstrap/
- .env
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- vendor/
- bootstrap/
tags:
- docker

npm:
image: lorisleiva/laravel-docker:latest
stage: build
script:
- npm install
- npm run prod
artifacts:
paths:
- public/mix-manifest.json
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- node_modules/
tags:
- docker

phpunit:
image: lorisleiva/laravel-docker:latest
stage: test
services:
- name: mysql:5.7
alias: mysql-test
- redis:latest
artifacts:
when: always
paths:
- storage/logs/
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- vendor/
- node_modules/
policy: pull
dependencies:
- composer
- npm
script:
- php artisan migrate
- php artisan db:seed --class=TestingSeeder
- php vendor/bin/phpunit --coverage-text --colors
tags:
- docker

dusk:
stage: test
cache:
key: ${CI_COMMIT_REF_NAME}
paths:
- vendor/
- node_modules/
policy: pull

services:
- name: mysql:5.7
alias: mysql-test

image: chilio/laravel-dusk-ci:stable
tags:
- docker
script:
- cp .env.dusk.gitlab-testing .env
- configure-laravel
- composer dump-autoload
- start-nginx-ci-project
- php artisan dusk --colors

artifacts:
paths:
- ./storage/logs # for debugging
- ./tests/Browser/screenshots
- ./tests/Browser/console
expire_in: 7 days
when: always

我想,它在 .yml 文件中缺少 MYSQL_PASSWORD 变量,但我不是 100% 确定。很高兴它现在可以工作了。

关于mysql - Gitlab CI 黄昏 - MySQL 连接被拒绝,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53794231/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com