Я пытаюсь настроить приложение Symfony 3.x с помощью Docker.
Я настроил 3 контейнера докера через файл docker-compose.yml:
Когда я перехожу на my-project.dev:8080/, я вижу простую страницу 404-Not found.
Я не вижу никаких записей в /var/log/nginx/access.log.
докер-compose.yml:
web:
image: nginx:latest
ports:
- "8080:80"volumes:
- .:/var/www
- ./docker/vhost.conf:/etc/nginx/sites-enabled/vhost.conf
- ./docker/nginx.conf:/etc/nginx/nginx.conf
links:
- php
php:
image: php:5.6-fpm
volumes:
- .:/var/www
links:
- db
db:
image: mysql:latest
volumes:
- /var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=my-password
Файл nginx.conf:
user www-data;
worker_processes 4;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
Файл vhost.conf:
server {
listen *:80;
server_name my-project.dev;
root /var/www/web;
location / {
# try to serve file directly, fallback to app.php
try_files $uri /app.php$is_args$args;
}
# DEV
# This rule should only be placed on your development environment
# In production, don't include this and don't deploy app_dev.php or config.php
location ~ ^/(app_dev|config)\.php(/|$) {
fastcgi_pass php:9000;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $realpath_root;
}
location ~ \.php$ {
return 404;
}
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
}
Я должен был переопределить WORKDIR изображения php-fpm, создав изображение следующим образом:
Dockerfile:
FROM php:5.6-fpm
MAINTAINER Firstname Lastname <[email protected]>
WORKDIR /var/www
Создать изображение:
docker build -t companyx/php-5.6-fpm .
Обновите файл docker-compose:
web:
image: nginx:latest
ports:
- "8080:80"volumes:
- .:/var/www
- ./docker/vhost.conf:/etc/nginx/sites-enabled/vhost.conf
- ./docker/nginx.conf:/etc/nginx/nginx.conf
links:
- php
php:
image: companyx/php-5.6-fpm
volumes:
- .:/var/www
links:
- db
db:
image: mysql:latest
volumes:
- /var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=my-password
Проблема в том, что с этим вашим определением:
location ~ ^/(app_dev|config)\.php(/|$) {
fastcgi_pass php:9000;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $realpath_root;
}
location ~ \.php$ {
return 404;
}
Вы используете страницу php, которая возвращает 404.
Вы должны изменить строку
try_files $uri /app.php$is_args$args;
в
try_files $uri /app_dev.php$is_args$args;