Nginx возвращает старые ответы HTTP - PullRequest
0 голосов
/ 05 марта 2019

У меня возникла проблема, когда Nginx кэширует некоторые HTTP-ответы.Не знаю почему?Я установил Nginx в Ubuntu 18.04 и никогда не менял значения cofig с nginx.conf file

Я служу Flask *Приложение 1012 * работает с MySQL , и когда я захожу на сайт, удаляю запись из таблицы и обновляю страницу, запись все еще там.но после нескольких запросов запись исчезает.однако после многократного запроса запись появляется снова, хотя при проверке базы данных ее нет и она успешно удаляется!

Следовательно, очевидно Nginx возвращает старые ответы HTTP из старого HTTPЗапросы без объяснения причин, а иногда и на самом деле возвращают свежие / правильные ответы HTTP

Обратите внимание, что, ребята, когда я запускаю автономный сервер Flask без Nginx, эта проблема больше существует.

Я также проверял Flaskрегистрируется в режиме реального времени, и иногда, когда я запрашиваю что-то из базы данных, Nginx возвращает ответ, даже не отправляя запрос в Flask.Таким образом, я на самом деле не вижу ни одного запроса, отправляемого во Flask, хотя я все еще получаю ответ, и он всегда имеет старые данные

, так что это определенно Nginx что вызвало его

nginx.conf (Файл)

user root;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
        worker_connections 768;
        # multi_accept on;
}

http {

        ##
        # Basic Settings
        ##

        sendfile off;
        tcp_nopush on;
        tcp_nodelay on;
        keepalive_timeout 6500;
        types_hash_max_size 2048;

 server_names_hash_bucket_size 64;
        # server_name_in_redirect off;

        include /etc/nginx/mime.types;
        default_type application/octet-stream;

        ##
        # SSL Settings
        ##

        ssl_protocols TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
        ssl_prefer_server_ciphers on;

        ##
        # Logging Settings
        ##

        access_log /var/log/nginx/access.log;
        error_log /var/log/nginx/error.log;

 # Gzip Settings
        ##

        gzip on;

        # gzip_vary on;
        # gzip_proxied any;
        # gzip_comp_level 6;
        # gzip_buffers 16 8k;
        # gzip_http_version 1.1;
        # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

        ##
        # Virtual Host Configs
        ##

        include /etc/nginx/conf.d/*.conf;
        include /etc/nginx/sites-enabled/*;
        client_max_body_size 50M;
        proxy_read_timeout 5m;
        proxy_send_timeout 300;
#mail {
#       # See sample authentication script at:
#       # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
#       # auth_http localhost/auth.php;
#       # pop3_capabilities "TOP" "USER";
#       # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
#       server {
#               listen     localhost:110;
#               protocol   pop3;
#               proxy      on;
#       }
#
#       server {
#               listen     localhost:143;
#               protocol   imap;
#               proxy      on;
#       }
#}

Я также использую uwsgi с флягой с несколькими рабочими и запускаю их как службу "systemctl", а вот *Файл 1036 * mywebsite.ini для него.Но, насколько мне известно, uwsgi по умолчанию не кэшируется.

[uwsgi]
module = application:app

master = true
processes = 5

socket = mywebsite.sock
chmod-socket = 660
vacuum = true
enable-threads = true
die-on-term = true

ОБНОВЛЕНИЕ 05/03/2019

Проблема связана с процессами uWSGI, а не с Nginx.Когда я изменил их на 0 в mywebsite.ini , он отлично работает без возврата неверных старых данных.Но я все еще хочу несколько процессов для лучшей производительности!есть идеи как?

...