nginx - Elixir Phoenix - 跟踪由对等错误重置的连接

标签 nginx elixir phoenix-framework

我正在运行一个非常高并发的 Phoenix 应用程序,我注意到大约 10% 的请求在读取上游时出现 readv() failed (104: Connection reset by peer)我的 nginx 错误文件中的错误。我在我的第一个插件的开头添加了一个日志语句来打印传入的请求,但我没有看到请求到达。我不知道为什么会收到此错误以及如何调试它。

附件是我的 nginx 配置文件的副本:

worker_processes 4;
user nginx nginx;

pid /var/run/nginx.pid;
error_log /var/log/nginx/error.log;

events {
  worker_connections 1024; # increase if you have lots of clients
  accept_mutex on; # "on" if nginx worker_processes > 1
  use epoll; # enable for Linux 2.6+
}

http {
  include mime.types;

  default_type application/octet-stream;
  access_log /var/log/nginx/access.log;
  error_log /var/log/nginx/error.log;
  sendfile on;
  tcp_nopush on;
  tcp_nodelay off;

  gzip on;
  gzip_http_version 1.0;
  gzip_proxied any;
  gzip_min_length 500;
  gzip_disable "MSIE [1-6]\.(?!.*SV1)";
  gzip_types text/plain text/xml text/css
             text/comma-separated-values
             text/javascript application/x-javascript
             application/atom+xml application/json;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_buffers 8 64k;
  proxy_buffer_size 128k;
  large_client_header_buffers 4 16k;

  upstream nolen {
    server 127.0.0.1:8080;
  }

  server {
      listen 80;
      server_name _;

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

      location / {
        try_files $uri @proxy;
      }

      location @proxy {
          proxy_redirect off;
          proxy_pass http://nolen;
      }
  }

  server {
    listen 443 ssl;
    server_name _;

    ssl_certificate /etc/ssl/selfsigned.crt;
    ssl_certificate_key /etc/ssl/selfsigned.key;
    ssl_ciphers HIGH:MEDIUM:!aNULL:!ADH:!DH:!EDH:!CAMELLIA:!KRB5:!IDEA:!EXP:!eNULL:!LOW:RC4+RSA:+HIGH:+MEDIUM;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

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

    location / {
      try_files $uri @proxy;
    }

    location @proxy {
        proxy_redirect off;
        proxy_pass http://nolen;
    }
  }

  include /etc/nginx/conf.d/cloudflare.conf;
}

我注意到采用不同查询参数的两个 url 以及静态 js 文件的服务都可以确认正常工作的错误。

任何人都可以帮助指导我完成调试此问题的过程吗?谢谢。

最佳答案

这通常是由于超时导致远程套接字上的连接丢失。对于您的测试,您可以在发送请求之前尝试 ping 检查状态,这就是为什么您能够隔离 10%

关于nginx - Elixir Phoenix - 跟踪由对等错误重置的连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42963073/

相关文章:

angular - Nginx for Angular没有达到后端api

elixir - 基于负载的Phoenix路由

phoenix-framework - ecto 中的模式限定查询

java - Https Ajax 跨域调用 session 超时

redirect - Nginx、gunicorn、python-flask 应用程序。 https 在重定向时丢失

node.js - 如何让我的堆栈保持活力

elixir - worker 和主管 Elixir 应用程序之间的区别

elixir - Elixir 应用中有多个主管

Elixir - Phoenix :undefined function Hex. SCM.managers

jquery - 如何向 Phoenix 项目添加 CSS/JS 依赖?