Symfony 2.6 на Docker nginx дает 404 - PullRequest
       10

Symfony 2.6 на Docker nginx дает 404

0 голосов
/ 02 октября 2019

В настоящее время работает над устаревшим приложением, созданным с Symfony 2.6 (Изначально приложение работает на Centos7 как на dev, так и на prod, но из-за нехватки времени мне просто нужно заставить его работать на локальном компьютере, чтобы я мог продолжить работу сзапросы функций).

Я добавляю Docker в проект, поскольку у меня возникают проблемы с управлением зависимостями на моем локальном компьютере.

Настройка:

  • ubuntu 18.04
  • nginx
  • Докер 19.03

Моя текущая проблема: - Я получаю 404 на всех маршрутах, которые я нажимаю. - Я вижу, есть журналы из docker logs <container> -f (Обновление: это журналы apache)

Журналы:

192.168.176.1 - - [01/Oct/2019:14:56:17 +0000] "GET /user HTTP/1.1" 404 209 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36"
192.168.176.1 - - [01/Oct/2019:14:57:51 +0000] "GET /user HTTP/1.1" 404 209 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36"
192.168.176.1 - - [02/Oct/2019:05:31:59 +0000] "GET /user HTTP/1.1" 404 209 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36"
//truncated

Это структура папок:

|app
|bin
|docker
    |app
        default
        Dockerfile
        php-fpm.conf
        start-container.sh
        supervisord.conf
|src
|vendor
|web
    app.php
    app_dev.php
    .htaccess
    //some other stuff
.env
.gitignore
composer.json
composer.lock
docker-compose.yml

Это ./web/.htaccess

DirectoryIndex app.php

<IfModule mod_rewrite.c>
    RewriteEngine On

RewriteCond %{REQUEST_URI}::$1 ^(/.+)/(.*)::\2$
    RewriteRule ^(.*) - [E=BASE:%1]

    RewriteCond %{HTTP:Authorization} .
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

    RewriteCond %{ENV:REDIRECT_STATUS} ^$
    RewriteRule ^app\.php(/(.*)|$) %{ENV:BASE}/$2 [R=301,L]
    RewriteCond %{REQUEST_FILENAME} -f
    RewriteRule .? - [L]

    RewriteRule .? %{ENV:BASE}/app.php [L]
</IfModule>

<IfModule !mod_rewrite.c>
    <IfModule mod_alias.c>
        RedirectMatch 302 ^/$ /app.php/
    </IfModule>
</IfModule>

Это ./docker/app/default

server {
    listen 80 default_server;

    root /var/www/html/public;

    index index.html index.htm index.php;

    server_name _;

    charset utf-8;

    location = /favicon.ico { log_not_found off; access_log off; }
    location = /robots.txt  { log_not_found off; access_log off; }

    location / {
        try_files $uri $uri/ /app.php$is_args$args;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php7.1-fpm.sock;
    }

    error_page 404 /app.php;
}

Это ./docker/app/Dockerfile

FROM ubuntu:18.04

LABEL maintainer="My name"

ENV DEBIAN_FRONTEND=noninteractive

RUN apt-get update \
    && apt-get install -y gnupg tzdata \
    && echo "Asia/Dubai" > /etc/timezone \
    && dpkg-reconfigure -f noninteractive tzdata \
    && apt-get install -y software-properties-common \
    && add-apt-repository -y ppa:ondrej/php

RUN apt-get update \
    && apt-get install -y curl zip unzip git supervisor sqlite3 make \
       nginx php7.1-fpm php7.1-cli \
       php7.1-pgsql php7.1-sqlite3 php7.1-gd \
       php7.1-curl php7.1-memcached \
       php7.1-imap php7.1-mysql php7.1-mbstring \
       php7.1-xml php7.1-zip php7.1-bcmath php7.1-soap \
       php7.1-intl php7.1-readline php7.1-xdebug \
       php-msgpack php-igbinary \
    && php -r "readfile('http://getcomposer.org/installer');" | php -- --install-dir=/usr/bin/ --filename=composer \
    && mkdir /run/php \
    && apt-get -y autoremove \
    && apt-get clean \
    && rm -rf /var/lib/apt/lists/\* /tmp/\* /var/tmp/\* \    //had to escape the * as it was commenting out the code in stackoverflow editor
    && echo "daemon off;" >> /etc/nginx/nginx.conf

RUN ln -sf /dev/stdout /var/log/nginx/access.log \
    && ln -sf /dev/stderr /var/log/nginx/error.log

ADD default /etc/nginx/sites-available/default
ADD supervisord.conf /etc/supervisor/conf.d/supervisord.conf
ADD php-fpm.conf /etc/php/7.1/fpm/php-fpm.conf
ADD start-container.sh /usr/bin/start-container
RUN chmod +x /usr/bin/start-container

ENTRYPOINT ["start-container"]

Это./docker-compose.yml

version: '3'
services:
  app:
    build: ./docker/app
    image: 'be/app:latest'
    networks:
      - appnet
    volumes:
      - './:/var/www/html:cached'
    ports:
      - '${APP_PORT}:80'
    working_dir: /var/www/html
  cache:
    image: 'redis:alpine'
    networks:
      - appnet
    volumes:
      - 'cachedata:/data'
  db:
    image: 'mysql:5.7'
    environment:
      MYSQL_ROOT_PASSWORD: '${DB_ROOT_PASSWORD}'
      MYSQL_DATABASE: '${DB_DATABASE}'
      MYSQL_USER: '${DB_USER}'
      MYSQL_PASSWORD: '${DB_PASSWORD}'
    ports:
      - '${DB_PORT}:3306'
    networks:
      - appnet
    volumes:
      - 'dbdata:/var/lib/mysql'
networks:
  appnet:
    driver: bridge
volumes:
  dbdata:
    driver: local
  cachedata:
    driver: local

Дополнительное примечание:

  • Я добавил Docker в другой устаревший проект, используя Symfony 2.8, и он работает.
  • Используя ту же настройку, что и в этом вопросе.

Любая помощь очень ценится.

Спасибо.

1 Ответ

0 голосов
/ 04 октября 2019

Я не слишком знаком с конфигами nginx, но, по моему мнению, root / var / www / html / public выглядит странно для старой Symfony, должен иметь web вместо public

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...