Nginx返回旧的HTTP响应

时间:2019-03-05 02:51:48

标签: nginx caching flask flask-sqlalchemy

我遇到一个问题,其中 Nginx 确实缓存了一些HTTP响应。不知道为什么我已经在Ubuntu 18.04上安装了 Nginx ,但从未更改 nginx.conf 文件中的任何配置文件

我正在为 MySQL 提供服务的 Flask 应用程序,发生的事情是当我转到网站并从表中删除记录并刷新页面时,记录仍然在那里。但是在多次请求之后,记录消失了。但是,在多次请求后,即使当我检查数据库时该记录仍不存在,记录仍会再次出现,并且记录已成功删除!

因此,很明显 Nginx 无缘无故地从旧的HTTP请求返回旧的HTTP响应,有时它确实返回了新的/正确的HTTP响应

请注意,当我在没有Nginx的情况下独立运行Flask服务器时,这个问题在那里存在的时间更长。

我还实时检查了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与带有多个工作器的flask一起使用,并将其作为服务“ systemctl”运行,这是它的 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。当我在 mywebsite.ini 中将它们更改为0时,它可以正常工作,而不会返回不正确的旧数据。但是我仍然想要多个过程以获得更好的性能!知道如何吗?

0 个答案:

没有答案