[web-devel] Content-Length on sendFile

Max Cantor mxcantor at gmail.com
Wed Jun 15 04:43:01 CEST 2011


For the record, the original post was about dynamic files, not the kind of static files served up by Yesod.Static.  

I put some comments in the haddocks on github. I think thats a fair place to start.

max

On Jun 15, 2011, at 10:29 AM, Michael Snoyman wrote:

> Let me point out one other distinction: sendFile versus yesod-static.
> The former is a function you would call from a normal handler, while
> yesod-static is the "magical" package which would actually know all of
> the stuff about your files at compile time. For the sendFile case, the
> only options for getting the file size are (1) the programmer manually
> adding the header and (2) Yesod automatically doing a system call to
> get it.
> 
> As for the behavior of Warp...  while I agree Kazu that we should
> reduce system call overhead, it might make sense for Warp to perform
> the system call to get file size *if* no content-length header is
> present.
> 
> And I'm still very uncomfortable setting the content-length header for
> static files based on compile-time information. In this case, having
> the wrong value (e.g., someone modified a CSS file after compiling)
> will completely break things and corrupt an open HTTP connection.
> 
> Michael
> 
> On Wed, Jun 15, 2011 at 5:22 AM, Kazu Yamamoto <kazu at iij.ad.jp> wrote:
>> Greg,
>> 
>>> I apologize for the confusing terminology. I am not differentiating between
>>> sending a static file with sendfile and a streaming response. I
>>> am differentiating between 2 different use cases for sending static files
>>> (with sendfile). For all of my web applications, I know what all the static
>>> files are and they will never change until I deploy another web application.
>>> That means I can stat the files once when the application is deployed and keep
>>> that information in memory. So I already have the file length information to
>>> include in the header, even though I don't do a file stat when the file is
>>> requested. wai-app-static and yesod-static supports these techniques.
>> 
>> Thanks. I think I understand. :)
>> 
>> So, do you support to *not* change the API (apps should add CL: by
>> themselves)?
>> 
>> --Kazu
>> 
>> _______________________________________________
>> web-devel mailing list
>> web-devel at haskell.org
>> http://www.haskell.org/mailman/listinfo/web-devel
>> 
> 
> _______________________________________________
> web-devel mailing list
> web-devel at haskell.org
> http://www.haskell.org/mailman/listinfo/web-devel




More information about the web-devel mailing list