asofyan
asofyan

Reputation: 317

Error: readv() failed (104: Connection reset by peer) while reading upstream

I have facebook apps with flask with nginx and uwsgi. When it receive POST from facebook, it always has error:

readv() failed (104: Connection reset by peer) while reading upstream

But when I access my apps directly (with GET method), it ran smoothly. What I've done:

  1. Limit @app.route with POST method only - doesn't work.
  2. Add limit in wsgi: uwsgi_buffer_size (in case request from facebook is big), and uwsgi_harakiri (in case uwsgi provide timeout before finish it request) - doesn't work.

I have workaround in django but can't figure out yet how to implement in flask. Could anyone help please?

Upvotes: 10

Views: 8624

Answers (2)

Collin Anderson
Collin Anderson

Reputation: 15454

The issue is that "upstream" (the actual process that nginx is proxing) is closing the connection.

In my case, Django is my web server and I needed to set DATA_UPLOAD_MAX_NUMBER_FIELDS to be larger because there were too many fields in the POST request.

Upvotes: 2

Yang Juven
Yang Juven

Reputation: 344

This is the bug of uwsgi. You can get more from [uWSGI] Several bugs .

The simple solution is that you must read the POST body by wsgi.input, even through POST body is null or you don't need POST params.

Upvotes: 4

Related Questions