Загрузка файла торнадо Nginx - PullRequest
1 голос
/ 14 июля 2011

Я пытаюсь загрузить файл через nginx_upload_module 2.2.0. У меня есть nginx 1.0.4, настроенный как обратный прокси-сервер с сервером торнадо на сервере. Ниже мой nginx.conf:

#user  nobody;
worker_processes  1;


#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

pid        /var/log/nginx.pid;


events {
    worker_connections  1024;
}


http {
include       mime.types;
index index.html
default_type  application/octet-stream;

#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  access.log  main;

sendfile        on;
#tcp_nopush     on;

#keepalive_timeout  0;
keepalive_timeout  65;

gzip  on;

upstream frontends {
    server 127.0.0.1:8888;
}



server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;

# Allow file uploads max 50M for example
    client_max_body_size 50M;

    #access_log  logs/host.access.log  main;
    error_log  /var/log/error.log info;


#POST URLn
    location /upload {
        # Pass altered request body to this location
        upload_pass @after_upload;

        # Store files to this directory
        upload_store /tmp;

        # Allow uploaded files to be read only by user
        upload_store_access user:rw;

        # Set specified fields in request body
        upload_set_form_field $upload_field_name.name “$upload_file_name”;
        upload_set_form_field $upload_field_name.content_type “$upload_content_type”;
        upload_set_form_field $upload_field_name.path “$upload_tmp_path”;

        # Inform backend about hash and size of a file
        upload_aggregate_form_field “$upload_field_name.md5” “$upload_file_md5”;
        upload_aggregate_form_field “$upload_field_name.size” “$upload_file_size”;

        #upload_pass_form_field “some_hidden_field_i_care_about”;

        upload_cleanup 400 404 499 500-505;
    }

location / {
        root   /opt/local/html;
    }


    location @after_upload {
        proxy_pass   http://127.0.0.1:8888;
    }

}
}

Я уже протестировал настройку, и nginx перенаправляет запрос на торнадо. Но когда я пытаюсь загрузить файл, он дает мне код состояния 400: Bad Request http. Если в журнале торнадо указано, что в запросе отсутствует файл upfile.path. И когда я пытаюсь перейти в папку, где nginx должен был предположительно сохранить загруженный файл, его там нет. И, следовательно, ошибка 400.

Может кто-нибудь указать, почему nginx не хранит файл в указанном каталоге / tmp?

Торнадо Бревно:

ВНИМАНИЕ: root: 400 POST / upload (127.0.0.1): отсутствует аргумент upfile_path ВНИМАНИЕ: root: 400 POST / upload (127.0.0.1) 2.31ms

Журнал ошибок Nginx:

127.0.0.1 - - [14 / Jul / 2011: 13: 14: 31 +0530] "POST / upload HTTP / 1.1" 400 73 "http://127.0.0.1/"" Mozilla / 5.0 (X11; Linux i686; версия 6.0) ) Gecko / 20100101 Firefox / 6,0 "

Более подробный журнал ошибок с опцией Info:

2011/07/14 16:17:00 [info] 7369 # 0: * 1 начал загрузку файла «statoverride» в «/ tmp / 0000000001» (поле «upfile», тип содержимого «application / octet-stream») ), клиент: 127.0.0.1, сервер: localhost, запрос: «POST / upload HTTP / 1.1», хост: «127.0.0.1», реферер: «http://127.0.0.1/"

2011/07/14 16:17:00 [info] 7369 # 0: * 1 завершил загрузку файла "statoverride" в "/ tmp / 0000000001", клиент: 127.0.0.1, сервер: localhost, запрос: "POST / upload HTTP / 1.1 ", хост:" 127.0.0.1 ", реферер:" http://127.0.0.1/"

2011/07/14 16:17:00 [info] 7369 # 0: * 1 завершил очистку файла "/ tmp / 0000000001" после состояния http 400 при закрытии запроса, клиент: 127.0.0.1, сервер: 0.0. 0.0: 80

Более подробный журнал ошибок с опцией отладки:

http://pastebin.com/4NVCdmrj

Редактировать 1: Итак, один момент, который мы можем вывести из приведенного выше журнала ошибок, заключается в том, что файл загружается с помощью nginx в / tmp, но впоследствии очищается. Не знаю почему, нужна помощь здесь.

1 Ответ

0 голосов
/ 14 июля 2011

Я только что написал веб-приложение с торнадо и nginx-upload-module, и оно работает. Судя по предоставленному вами журналу торнадо, вы можете попытаться изменить свой код

self.get_argument('upfile_path')

до

self.get_argument ('upload_tmp_path')

nginx сохранил файл, но "upload_cleanup 400 404 499 500-505;" эта строка указывает очистить файл, когда ваше приложение ответит указанным HTTP-кодом.

...