У меня есть среда, построенная на контейнерах докеров (в boot2docker). У меня есть следующий файл docker-compose.yml для быстрой настройки серверов nginx и nexus:
version: '3.2'
services:
nexus:
image: stefanprodan/nexus
container_name: nexus
ports:
- 8081:8081
- 5000:5000
nginx:
image: nginx:latest
container_name: nginx
ports:
- 5043:443
volumes:
- /opt/dm/nginx2/nginx.conf:/etc/nginx/nginx.conf:ro
Nginx имеет следующую конфигурацию (nginx.conf)
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
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;
proxy_send_timeout 120;
proxy_read_timeout 300;
proxy_buffering off;
keepalive_timeout 5 5;
tcp_nodelay on;
server {
listen 80;
server_name demo.com;
return 301 https://$server_name$request_uri;
}
server {
listen 443 ssl;
server_name demo.com;
# allow large uploads of files - refer to nginx documentation
client_max_body_size 1024m;
# optimize downloading files larger than 1G - refer to nginx doc before adjusting
#proxy_max_temp_file_size 2048m
#ssl on;
#ssl_certificate /etc/nginx/ssl.crt;
#ssl_certificate_key /etc/nginx/ssl.key;
location / {
proxy_pass http://nexus:8081/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto "https";
}
}
}
Нексус вроде работает очень хорошо. Я успешно звоню curl http://localhost:8081
на хост-машину docker. Это вернет мне html сайта входа в систему nexus. Теперь хочу попробовать сервер nginx. Он настроен на прослушивание порта 443, но SSL сейчас отключен (я хотел протестировать его перед тем, как погрузиться в конфигурацию SSL). Как вы могли заметить, мой контейнер ngix сопоставляет порт 443 с портом 5043. Таким образом, я пытаюсь использовать следующую команду curl: curl -v http://localhost:5043/
. Теперь я ожидаю, что мой http-запрос будет отправлен на nginx и проксирован на proxy_pass http://nexus:8081/;
nexus. Имя хоста Nexus отображается в сети контейнеров докеров и доступно из контейнера nginx. К сожалению, в ответ я получаю:
* Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 5043 (#0)
> GET / HTTP/1.1
> Host: localhost:5043
> User-Agent: curl/7.49.1
> Accept: */*
>
* Empty reply from server
* Connection #0 to host localhost left intact
curl: (52) Empty reply from server
Я проверял журналы nginx, ошибки, доступ, но эти журналы пусты. Может кто-нибудь помочь мне решить эту проблему? Это должен быть простой пример проксирования запросов, но, может быть, я неправильно понимаю какую-то концепцию?
docker-compose logs
и покажите мне вывод, пожалуйста. - person Bukharov Sergey   schedule 24.10.2017