Welcome! Log In Create A New Profile

Advanced

Re: custom handler module - dynamic response with unknown content length

Yasser Zamani
March 01, 2014 04:20AM
Thanks for your response....

On Sat 01 Mar 2014 03:41:24 AM IRST, Maxim Dounin wrote:
> Hello!
>
> You've tried to send the same chain with the same buffer multiple
> times. After a buffer is sent for the first time, its pointers
> are adjusted to indicate it was sent - b->pos moved to b->last, and
> buffer's size become zero. Second attempt to send the same buffer
> will expectedly trigger the "zero size buf" check.
>
Great! I tried:

for(i=1;i<10000000;i++){b->flush =
(0==(i%100));rc=ngx_http_output_filter(r,
&out);if(rc!=NGX_OK){ngx_log_error(NGX_LOG_ALERT,r->connection->log,0,"bad
rc, rc:%d", rc);return rc;}b->pos = ngx_hello_string;b->last =
ngx_hello_string + sizeof(ngx_hello_string) - 1;b->memory =
1;b->last_buf = 0;}

which now fails with:

2014/03/01 12:23:39 [alert] 5022#0: *1 bad rc, rc:-2, client:
127.0.0.1, server: localhost, request: "GET / HTTP/1.1", host:
"localhost:8080"
2014/03/01 12:23:39 [alert] 5022#0: *1 zero size buf in writer t:0 r:0
f:0 00000000 080C7431-080C7431 00000000 0-0, client: 127.0.0.1, server:
localhost, request: "GET / HTTP/1.1", host: "localhost:8080"

And to resolve this I know I should follow the solution at [3].
[3] http://web.archiveorange.com/archive/v/yKUXMLzGBexXA3PccJa6

But is this a clean way to call 'ngx_http_output_filter' more than
once? (please see below to know why I have to call it multiple times)

FYI: Previous try did not fail in SECOND attempt but it failed when
client successfully download 936 bytes of repeated "Hello, World!"s (72
attempts).

> Trivial aproach is to prepare full output chain, and then send it
> using single ngx_http_output_filter() call.

The full output chain will be usually a long video which is not a file
but will be generated in memory on the fly. I have to send each chunk
as soon as it's ready because the stream generation is time consuming
and client COULD NOT wait for all to be done. Suppose it's a 1 hour
video which dynamically has been generated and I would like to send
each minute as soon as it's ready without waiting for all 1 hour
transcoding. I'm aware about nginx's mp4 module but it does not support
time consuming dynamically generated video on memory.

WHAT WILL BE THE CORRECT WAY TO DO THIS IN NGINX?

Thanks again!

_______________________________________________
nginx mailing list
nginx@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx
Subject Author Posted

custom handler module - dynamic response with unknown content length

Yasser Zamani February 28, 2014 02:16PM

Re: custom handler module - dynamic response with unknown content length

Maxim Dounin February 28, 2014 07:12PM

Re: custom handler module - dynamic response with unknown content length

Yasser Zamani March 01, 2014 04:20AM

Re: custom handler module - dynamic response with unknown content length

Maxim Dounin March 01, 2014 06:32AM

Re: custom handler module - dynamic response with unknown content length

Yasser Zamani March 01, 2014 09:58AM

Re: custom handler module - dynamic response with unknown content length

Yasser Zamani March 01, 2014 12:28PM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 300
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready