Symfony和Docker - 缓存和日志目录权限

时间:2016-01-31 20:23:51

标签: php symfony docker file-permissions docker-compose

我正在尝试使用docker设置Symfony项目,但总是给出与“cache”目录中的权限相关的错误。

我已经尝试了一切,但似乎无法找到解决方案。 问题是以某种方式缓存文件夹是用“root”所有者创建的,即使我的服务器和php-fpm用户设置为www-data。也许是因为php-cli用户?

我试过了: - setfacl:不使用docker - chown / chmod到www-data:也没用。它可能会在开始时正确地更改所有者,但是在其他地方会出现错误。

搬运工-compose.yml

app:
  build: .
  command: "tail -f /dev/null" # keep the application container running
  links:
      - mysql
  volumes:
    - .:/var/www

nginx:
  build: docker/nginx/
  ports:
    - 8090:80
  links:
    - php-fpm
  volumes_from:
    - app

php-fpm:
  build: docker/fpm
  ports:
    - 9000:9000
  volumes_from:
    - app

mysql:
  image: mysql:5.7
  volumes:
     - ./docker/data/mysql:/var/lib/mysql

我的应用Dockerfile:

FROM php:5.6-cli

ENV DEBIAN_FRONTEND noninteractive

RUN apt-get update && apt-get install -y \
    git \
    vim \
    curl \
    php5-json \
    php5-intl \
    php5-mcrypt \
    php5-mysql \
    php5-apcu \
    php5-gd

ADD /docker/fpm/php.ini /usr/local/etc/php/

# install composer.
RUN curl -sS https://getcomposer.org/installer | php
RUN mv composer.phar /usr/local/bin/composer

RUN usermod -u 1000 www-data

ADD . /var/www

WORKDIR /var/www

PHP-fpm Dockerfile

FROM php:5.6-fpm

ENV DEBIAN_FRONTEND noninteractive

RUN apt-get update && apt-get install -y \
    php5-json \
    php5-intl \
    php5-mcrypt \
    php5-mysql \
    php5-apcu \
    php5-gd

RUN apt-get install -y php5-xdebug
ADD xdebug.ini /usr/local/etc/php/conf.d/
ADD php.ini /usr/local/etc/php/

EXPOSE 9000

WORKDIR /var/www   
CMD ["php-fpm"]

Nginx Dockerfile

FROM nginx:latest


ENV DEBIAN_FRONTEND noninteractive

RUN apt-get update && apt-get install -y git vim
ADD nginx.conf /etc/nginx/
ADD symfony.conf /etc/nginx/sites-available/

RUN mkdir -p /etc/nginx/sites-enabled
RUN ln -s /etc/nginx/sites-available/symfony.conf /etc/nginx/sites-enabled/

RUN usermod -u 1000 www-data

EXPOSE 80
EXPOSE 443

ENTRYPOINT ["nginx"]

我没有想法。有什么建议? 谢谢。

2 个答案:

答案 0 :(得分:0)

我有一个带有docker的apache 2.2设置,在Dockerfile的末尾我有以下命令:

Router.route '/home', name: 'home' template:'homepage' waitOn:-> Meteor.subscribe 'latestPrograms', personalFullName data:-> {latestPrograms: latestPrograms.find()}

,这在fix_symfony_cache_and_logs_permissions脚本中:

ENTRYPOINT service apache2 start && sh /opt/fix_symfony_cache_and_logs_permissions.sh

似乎您的问题可能与您的php-fpm进程应该以正确的权限运行的那个事实有关。

编辑:我刚刚发现了https://github.com/drgomesp/symfony-docker,我认为这有助于您正确设置

答案 1 :(得分:-1)

我也有这个问题。没有任何效果, <!DOCTYPE html> <html lang="en" dir="rtl"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Shafayat</title> <link href="css/bootstrap.css" rel="stylesheet"> chownchmod。然后最终得到以下解决方案。 警告,我的解决方案在读/写方面存在一些安全问题。使用它需要您自担风险!

setfacl

apache2.conf 文件内容如下。

FROM php:5.6.29-apache

RUN apt-get update \
  && apt-get install -y git libssl-dev zlib1g-dev libicu-dev g++ \
  && docker-php-ext-install intl mbstring zip \
  && a2enmod rewrite
RUN pecl install mongo \
  && echo extension=mongo.so > /usr/local/etc/php/conf.d/mongo.ini \
  && docker-php-ext-enable mongo \
  && pecl install mongodb && \
  docker-php-ext-enable mongodb

COPY apache2.conf /etc/apache2/apache2.conf

COPY . /var/www/html

WORKDIR /var/www/html

RUN rm -rf /var/www/html/var/cache/prod \
    && rm -rf /var/www/html/var/cache/dev

RUN chown -R www-data /var/www
RUN chmod -R 777 /var/www

USER www-data

RUN curl -sS https://getcomposer.org/installer | php

RUN php composer.phar install --no-interaction --optimize-autoloader

USER root