微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

django – Gunicorn没有从nginx记录真正的ip

我通过gunicorn,supervisor和Nginx作为反向代理运行django应用程序并努力让我的gunicorn访问日志显示实际的ip而不是127.0.0.1:

日志条目目前看起来像这样:

127.0.0.1 - - [09/Sep/2014:15:46:52] "GET /admin/ HTTP/1.0" ...

supervisord.conf

[program:gunicorn]
command=/opt/middleware/bin/gunicorn --chdir /opt/middleware -c /opt/middleware/gunicorn_conf.py middleware.wsgi:application 
stdout_logfile=/var/log/middleware/gunicorn.log

gunicorn_conf.py

#!python
from os import environ
from gevent import monkey
import multiprocessing
monkey.patch_all()

bind = "0.0.0.0:9000"
x_forwarded_for_header = "X-Real-IP"
policy_server = False
worker_class = "socketio.sgunicorn.GeventSocketIOWorker"   
accesslog = '-'

我的Nginx模块conf

server {
    listen 80;
    root /opt/middleware;
    index index.html index.htm;
    client_max_body_size 200M;
    server_name _;

    location / {
        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_redirect off;
        real_ip_header X-Real-IP;

      }
    }

我在location {}块中尝试了各种组合,但看不出它有什么不同.任何暗示赞赏.

解决方法:

问题是您需要配置gunicorn‘s logging,因为它(认情况下)不会显示任何自定义标头.

从文档中,我们发现认访问日志格式由access_log_format控制,并设置为以下内容

"%(h)s %(l)s %(u)s %(t)s "%(r)s" %(s)s %(b)s "%(f)s" "%(a)s"

哪里:

> h是远程地址
> l是 – (未使用)
>你是 – (未使用,保留)
> t是时间戳
> r是状态行
> s是请求的状态
> b是响应的长度
> f是推荐人
> a是用户代理

您还可以使用以下认情况下未使用的额外变量对其进行自定义

> T – 请求时间(以秒为单位)
> D – 请求时间(以微秒为单位)
> p – 进程ID
> {Header} i – 请求标题(自定义)
> {Response} o – 响应标头(自定义)

对于gunicorn,所有请求都来自Nginx,因此它将显示为远程IP.要让它记录任何自定义标题(您从Nginx发送的内容),您需要调整此参数并添加适当的变量,在您的情况下,您可以将其设置为以下内容

%(h)s %(l)s %(u)s %(t)s "%(r)s" %(s)s %(b)s "%(f)s" "%(a)s" "%({X-Real-IP}i)s"

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐