Не удается загрузить ресурсы, отправленные на сервер HTTP / 2 (HTTP2_CLIENT_REFUSED_STREAM) - PullRequest
3 голосов
/ 04 февраля 2020

У меня есть следующая ошибка ERR_HTTP2_CLIENT_REFUSED_STREAM в chrome консоли devtools для всех или некоторых активов, передаваемых через http2.

ERR_HTTP2_CLIENT_REFUSED_STREAM

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

Я использую nginx с включенным http2 (ssl через certbot) и cloudflare.

server {
    server_name $HOST;
    root /var/www/$HOST/current/public;

    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-XSS-Protection "1; mode=block";
    add_header X-Content-Type-Options "nosniff";

    index index.html index.htm index.php;

    charset utf-8;

    set $auth "dev-Server.";

    if ($request_uri ~ ^/opcache-api/.*$){
    set $auth off;
    }

    auth_basic $auth;
    auth_basic_user_file /etc/nginx/.htpasswd;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location = /favicon.ico { access_log off; log_not_found off; }
    location = /robots.txt  { access_log off; log_not_found off; }

    error_page 404 /index.php;

    location ~ \.php$ {
        fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
        include fastcgi_params;
    }

    location ~ /\.(?!well-known).* {
        deny all;
    }

    location ~* \.(?:css|js)$ {
        access_log off;
        log_not_found off;
        # Let laravel query strings burst the cache
          expires 1M;
          add_header Cache-Control "public";
        # Or force cache revalidation.
          # add_header Cache-Control "public, no-cache, must-revalidate";
    }

    location ~* \.(?:jpg|jpeg|gif|png|ico|xml|svg|webp)$ {
        access_log off;
        log_not_found off;
        expires 6M;
        add_header Cache-Control "public";
    }

    location ~* \.(?:woff|ttf|otf|woff2|eot)$ {
        access_log        off;
        log_not_found     off;
        expires max;
        add_header Cache-Control "public";
        types     {font/opentype otf;}
        types     {application/vnd.ms-fontobject eot;}
        types     {font/truetype ttf;}
        types     {application/font-woff woff;}
        types     {font/x-woff woff2;}
    }


    listen 443 ssl http2;
    ssl_certificate /etc/letsencrypt/live/$HOST/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/$HOST/privkey.pem; # managed by Certbot
    # include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

}
server {
    if ($host = $HOST) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    server_name $HOST;
    listen 80;
    return 404; # managed by Certbot


}

Поиск этой ошибки не дает много результатов, и если это помогает, это приложение laravel 6, которое выдвигает эти активы, если я отключаю активы, нажимая laravel, то все активы загружаются правильно.

Я даже не знать, с чего начать поиск.


Обновление 1

Я включил chrome ведение журнала и проверил журналы, используя Sawbuck, следуя инструкциям здесь и нашел что фактическая ошибка связана с HTTP-ответом 414, что подразумевает некоторую проблему с кэшированием.

log


Обновление 2

Я нашел это замечательно Браузер может прерывать нажатые элементы если они уже есть , что гласит следующее:

Chrome будет отклонять нажатия, если у него уже есть элемент в кэше pu sh. Он отклоняет с PROTOCOL_ERROR вместо CANCEL или REFUSED_STREAM.

, он также ссылается на некоторые chrome и mozilla ошибок.

Что привело меня к полному отключению cloudflare и тестированию непосредственно с сервером, я попробовал различные директивы Cache-Control, а также попытался отключить заголовок, но такая же ошибка возникает при refre sh после очистки кэша.

По-видимому, chrome отменяет отправленный актив http / 2 , даже если его нет в pu sh кэше , оставляя страницу неработающей.

Для Теперь я отключаю http / 2 серверное приложение pu sh в laravel как временное исправление.

...