Welcome! Log In Create A New Profile

Advanced

Re: Parallel subrequests for multi-source long polling?

agentzh
November 18, 2009 03:28AM
On Wed, Nov 18, 2009 at 2:30 PM, shaun <nginx-forum@nginx.us> wrote:
> Here's a description of what I'm hoping to accomplish:

Here's a proposal for your consideration:

1. You need a content handler and an output filter to work together.
2. Use a content handler to issue all the subrequests (to all your
upstream backends). We assume the content handler lives in the main
request.
3. When starting each subrequest, the content handler feeds a
"post_subrequest" handle and the main request's ctx object into the
ngx_http_subrequest call. Also, the content handler registers a ctx
object to the subrequest object to inform the subrequest's output
filter to buffer the response.
4. In your output filter, first check if there's a ctx object
associated with the current request. If yes, then you're filtering one
of the subrequests that your content handler starts. So now simply
buffer the response chain link in this ctx object (in meomory or on
disk, it's up to you).
5. In your "post_subrequest" handle, check the main request's ctx
object (it should the the last argument passed in). We assume there's
a "success" flag and a "failures" counter in that ctx object (both are
zeroed initially), as well as the total number of subrequests. If
"success" flag is not set and if the current subrequest succeeds,
simply return the buffered response contents in your subrequest's ctx
object, and set a "success" flag in your main request's ctx object. If
the current subrequest fails, then increment the "failures" counter.
If the "failures" counter reaches the total number of the subrequests
(which means all tests are failed), then returns the final failure
(and set the main request's status code if appropriate and send
headers for the main request.)

Your main request, i.e., the content handler should not send headers
or any contents by itself and should return NGX_DONE.

I think this model should work after my various experiments in the
"echo" module, but I could be wrong ;) Feel free to tell us your
findings on your way :)

Good luck!
-agentzh
Subject Author Posted

Parallel subrequests for multi-source long polling?

shaun November 18, 2009 01:30AM

Re: Parallel subrequests for multi-source long polling?

Piotr Sikora November 18, 2009 02:28AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 18, 2009 03:28AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 18, 2009 03:30AM

Re: Parallel subrequests for multi-source long polling?

shaun November 18, 2009 04:22AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 18, 2009 11:30PM

Re: Parallel subrequests for multi-source long polling?

shaun November 19, 2009 03:54AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 19, 2009 04:58AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 19, 2009 06:32AM

Re: Parallel subrequests for multi-source long polling?

shaun November 19, 2009 02:20PM

Re: Parallel subrequests for multi-source long polling?

Piotr Sikora November 19, 2009 03:28PM

Re: Parallel subrequests for multi-source long polling?

shaun November 19, 2009 04:08PM

Re: Parallel subrequests for multi-source long polling?

Piotr Sikora November 19, 2009 05:42PM

Re: Parallel subrequests for multi-source long polling?

shaun November 20, 2009 03:33AM

Re: Parallel subrequests for multi-source long polling?

Piotr Sikora November 20, 2009 04:48AM

Re: Parallel subrequests for multi-source long polling?

agentzh November 20, 2009 05:28AM

Re: Parallel subrequests for multi-source long polling?

shaun November 20, 2009 06:41AM

Re: Parallel subrequests for multi-source long polling?

shaun November 21, 2009 09:12PM

Re: Parallel subrequests for multi-source long polling?

Piotr Sikora November 21, 2009 10:10PM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 172
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 500 on July 15, 2024
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready