Are there optimizations for proxying larger file sizes? #853
                  
                    
                      deanebarker
                    
                  
                
                  started this conversation in
                General
              
            Replies: 1 comment
-
| I'm also interested in this topic. I need to check a few keys in redis before forwarding the s3 bucket URL to the client. | 
Beta Was this translation helpful? Give feedback.
                  
                    0 replies
                  
                
            
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
        
    
Uh oh!
There was an error while loading. Please reload this page.
Uh oh!
There was an error while loading. Please reload this page.
-
Years ago, I wrote a proxy in C#.
I have recently re-written this in Node (v2.0.6), using this library on Express.
I've been doing some testing. I have both proxies running locally on the same hardware with the same network connection, pointed at the same endpoint.
Across 5,000 requests to each proxy (actual requests to URLs on the endpoint), the performance of both are very similar (number is the average time of request completion).
This difference (about 15%) could be caused by any number of things, so I don't consider it material.
However, notably, the difference is far more pronounced when proxying files, rather than simple HTML. Example:
This is a 34% difference, up from 15%. The difference is very consistent across test runs (the highest I recorded was 45%).
(I realize that "files" and "HTML" are both just bytes, but the average file is far larger than the average HTML payload, so perhaps it's more accurate to say this difference occurs with larger proxy payloads.)
Is there any particular optimization for handling larger payloads? Anything I should be doing that might account for the increasing performance difference as the payload sizes go up?
Here's the code for the middleware, which you can see is pretty simple.
(Note: the
templateResponsedoes nothing of note for files -- it exits at the top of the method forcontent-typeheaders that start withimage. I did remove that completely for one test run, so that it was never even called, and that dropped the difference by a bit -- down to 32%.)Is there a configuration setting or optimization I should be using?
Beta Was this translation helpful? Give feedback.
All reactions