Я попал в браузер:
404 Not Found
nginx/1.13.10
и в логах у меня появилось:
$ ls logs/
nginx-access.log nginx-error.log
$ cat logs/*
172.17.0.1 - - [27/Mar/2018:02:11:35 +0000] "GET / HTTP/1.1" 404 572 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36" "-"
2018/03/27 02:11:35 [error] 5#5: *1 "/var/wwww/html/index.php" is not found (2: No such file or directory), client: 172.17.0.1, server: localhost, request: "GET / HTTP/1.1", host: "localhost"
Мой nginx/nginx.conf
выглядит так:
server {
listen 80;
# this path MUST be exactly as docker-compose.fpm.volumes,
# even if it doesn't exists in this dock.
root /var/wwww/html;
index index.php index.html index.html;
server_name localhost;
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass phpfpm:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
}
}
Мой docker-compose.yml
выглядит как:
nginx:
image: nginx
restart: always
ports:
- "80:80"
links:
- phpfpm
- db
volumes:
- ./logs/nginx-error.log:/var/log/nginx/error.log
- ./logs/nginx-access.log:/var/log/nginx/access.log
- ./nginx/nginx.conf:/etc/nginx/conf.d/default.conf
- ./public/:/var/www/html
phpfpm:
build: ./mGSV
restart: always
ports:
- "9000:9000"
links:
- db
volumes:
- ./public/:/var/www/html
db:
image: mariadb
restart: always
environment:
- MYSQL_ROOT_PASSWORD=admin
- MYSQL_DATABASE=mgsv
- MYSQL_USER=mgsv_user
- MYSQL_PASSWORD=mgsvpass
ports:
- "3306:3306"
volumes:
- ./mysql/:/docker-entrypoint-initdb.d
phpmyadmin:
image: phpmyadmin/phpmyadmin
restart: always
links:
- db
ports:
- 8183:80
environment:
PMA_USER: root
PMA_PASSWORD: admin
PMA_ARBITRARY: 1
Мой ./mGSV/Dockerfile
основывается на:
FROM php:5-fpm
Что я пропустил?
Заранее спасибо.
Я не знаком с докером, но вижу здесь 2 несоответствия:
Независимо от части докера, nginx (nginx/nginx.conf
) пытается обслуживать контент из / var /wwww/ html. Вероятно, это опечатка (вы имели в виду /var/www/html
?). Таким образом, точное сообщение об ошибке "/var/wwww/html/index.php" is not found (2: No such file or directory)
- в этой папке должно быть содержимое, чтобы эта конфигурация nginx работала.
Также ваш комментарий nginx говорит # this path MUST be exactly as docker-compose.fpm.volumes
, но phpfpm тома в вашем docker-compose.yml говорит ./public/:/var/www/html
.
Чего вы на самом деле пытаетесь достичь?