我正在尝试将docker nginx
与docker flask
联系起来。这是我项目的结构:
.
├── storage
│ ├── nginx
│ │ └── static
│ │ └── image.gif
└── web
└── flask
├── app
│ ├── run.py
│ └── templates
│ └── index.html
├── conf
│ ├── nginx-default.conf
│ ├── nginx-flask.conf
│ └── requirements.txt
└── Dockerfile
虽然curl 127.0.0.1:50
和curl 127.0.0.1:80/static/image.gif
工作正常但我在curl 127.0.0.1
时收到'403 Forbidden'错误。更具体地说,nginx
会出现以下错误:
2016/03/05 17:54:37 [error] 8#8: *1 directory index of "/usr/share/nginx/html/" is forbidden, client: 172.17.0.1, server: localhost, request: "GET / HTTP/1.1", host: "localhost"
172.17.0.1 - - [05/Mar/2016:17:54:37 +0000] "GET / HTTP/1.1" 403 169 "-" "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:44.0) Gecko/20100101 Firefox/44.0" "-"
我像这样创建容器:
docker create \
-v $ROOT/web/flask/app/:/web/flask/app/ \
--name flask_data flask:0.1
docker run \
-d -p 127.0.0.1:50:50 \
--volumes-from flask_data \
--name flask_service flask:0.1
docker create \
-v $ROOT/storage/nginx/:/usr/share/nginx/html/ \
--name nginx_data nginx:1.9
docker run \
-v $ROOT/web/flask/conf/nginx-flask.conf:/etc/nginx/conf.d/nginx-flask.conf \
-v $ROOT/web/flask/conf/nginx-default.conf:/etc/nginx/conf.d/default \
-d -p 127.0.0.1:80:80 \
--volumes-from nginx_data \
--link flask_service:flask_service_alias \
--name nginx_service nginx:1.9
其中,Dockerfile
是:
FROM ubuntu:14.04
RUN apt-get update && apt-get install -y --no-install-recommends python-pip python-dev
COPY . /web/flask/
RUN pip install -r /web/flask/conf/requirements.txt
CMD gunicorn run:app --workers=4 --bind=0.0.0.0:50 --log-level=debug --timeout=43200 --chdir=/web/flask/app/
和requirements.txt
是:
gunicorn==19.4.5
Flask==0.10.1
Flask-Redis==0.1.0
Flask-SQLAlchemy==2.1
Flask-MongoAlchemy==0.7.2
nginx-default
为空,nginx-flask
为:
server {
listen 80;
charset utf-8;
location /avatar {
alias /usr/share/nginx/html/avatar;
}
location /scan {
alias /usr/share/nginx/html/scan;
}
location /static {
alias /usr/share/nginx/html/static;
}
location / {
proxy_pass http://flask_service_alias:50/;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
任何想法?
答案 0 :(得分:4)
default.conf
图片中的nginx
文件正在接管/
位置,看起来可能会发生什么。你的nginx run命令有:
-v $ROOT/web/flask/conf/nginx-default.conf:/etc/nginx/conf.d/default \
这应该覆盖default.conf
而不是default
。目前的情况是,它只是添加了另一个空白default
文件,并保留了default.conf
的默认位置{/ 1}}。
您的静态路由确实有效,因为/
到nginx-flask.conf
中有明确的路由,您可以明确地调用该文件。您在/static
位置获得403
,因为默认情况下会禁用索引(由/
选项控制)。