【发布时间】:2021-06-01 12:43:11
【问题描述】:
我正在尝试为提供我的烧瓶应用程序的 gunicorn 应用程序服务器设置 nginx 反向代理。 gunicorn 容器监听 5000 端口,nginx 监听 80 端口。问题是我仍然可以通过浏览器访问应用程序访问 localhost:5000,即使我已将 gunicorn 设置为仅监听 docker 容器的 localhost,并且所有请求都应该通过 nginx 容器通过端口 80 传递到 gunicorn 容器。这是我的设置。
docker-compose.yml
version: "3.3"
services:
web_app:
build:
context: .
dockerfile: Dockerfile.web
restart: always
ports:
- "5000:5000"
volumes:
- data:/home/microblog
networks:
- web
web_proxy:
container_name: web_proxy
image: nginx:alpine
restart: always
ports:
- "80:80"
volumes:
- data:/flask:ro
- ./nginx/config/nginx.conf:/etc/nginx/nginx.conf:ro
networks:
- web
networks:
web:
volumes:
data:
Dockerfile.web
FROM python:3.6-alpine
# Environment Variables
ENV FLASK_APP=microblog.py
ENV FLASK_ENVIRONMENT=production
ENV FLASK_RUN_PORT=5000
# Don't copy .pyc files to cointainer
ENV PYTHONDONTWRITEBYTECODE=1
# Security / Permissions (1/2)
RUN adduser -D microblog
WORKDIR /home/microblog
# Virtual Environment
COPY requirements.txt requirements.txt
RUN python -m venv venv
RUN venv/bin/pip install -U pip
RUN venv/bin/pip install -r requirements.txt
RUN venv/bin/pip install gunicorn pymysql
# Install App
COPY app app
COPY migrations migrations
COPY microblog.py config.py boot.sh ./
RUN chmod +x boot.sh
# Security / Permissions (2/2)
RUN chown -R microblog:microblog ./
USER microblog
# Start Application
EXPOSE 5000
ENTRYPOINT ["./boot.sh"]
boot.sh
#!/bin/sh
source venv/bin/activate
flask db upgrade
exec gunicorn --bind 127.0.0.1:5000 --access-logfile - --error-logfile - microblog:app
即使我设置了gunicorn --bind 127.0.0.1:5000', in stdout of docker-compose` 我明白了
web_app_1 | [2021-03-02 22:54:14 +0000] [1] [INFO] Starting gunicorn 20.0.4
web_app_1 | [2021-03-02 22:54:14 +0000] [1] [INFO] Listening at: http://0.0.0.0:5000 (1)
我仍然可以在浏览器中从端口 5000 看到该网站。当我明确将其设置为 127.0.0.1 时,我不确定它为什么会在 0.0.0.0 上收听。
【问题讨论】:
标签: docker nginx flask gunicorn