Я разрабатываю веб-сайт в полностью автономной среде. также я использую gitlab runner для CI, а хост — CentOS 7.
проблема в том, что gitlab runner использует пользователя gitlab-runner
в centos для развертывания приложения laravel, а apache использует пользователя apache
для запуска laravel. Я получил ошибку Permission denied
в apache, пока не сменил владельца файлов. после этого я получаю эту ошибку в журнале apache:
Uncaught UnexpectedValueException: The stream or file "storage/logs/laravel.log" could not be opened: failed to open stream: Permission denied
кажется, что некоторые библиотеки поставщиков, такие как monolog
, хотят записывать журналы ошибок или отладки в storage/logs/laravel.log
, но им отказывают в разрешении. :(
.gitlab-ci.yml
stages:
- build
- test
- deploy
buildBash:
stage: build
script:
- bash build.sh
testBash:
stage: test
script:
- bash test.sh
deployBash:
stage: deploy
script:
- sudo bash deploy.sh
build.sh
#!/bin/bash
set -xe
# creating env file from production file
cp .env.production .env
# initializing laravel
php artisan key:generate
php artisan config:cache
# database migration
php artisan migrate --force
развернуть.sh
#!/bin/bash
PWD=$(pwd)'/public'
STG=$(pwd)'/storage'
ln -s $PWD /var/www/html/public
chown apache.apache -R /var/www/html/public
chmod -R 755 /var/www/html/public
chmod -R 775 $STG
Правильно ли я использую gitlab runner? как я могу исправить ошибку отказа в разрешении?