Hi Amos, thank you for your response. I think I didn't explain the problem correctly. Let me mention that the http-Post request contains - one or two URLs, - name and parameters of one mathematical function from a set of server functions, - mime-type of the response.
The client sends a http-Post request to the server The server ... (1) fetches the data (xml, up to 100 MB) via http-Get using the reference which is embedded in the client http-Post request, (2) computes a complete new dataset (xml, up to 100 MB) using the fetched data and the requested function and parameters, (3) converts the dataset to the requested mime-type, (4) returns the resulting dataset as a response of the http-Post request to the client. If we would implement a simple server cache the process would be like this: (- client sends request via http-Post to the server) - server generates a unique key of the client http-Post request, because the URL of the http-Post request is always the same, - server checks if the unique key / filename is in the cache; no: normal process, - server checks via http-Head (origin server) if the cached data is fresh: no normal process, - server sends the cached data associated to the unique key / filename as response of the http-Post request to the client; end, - normal process: server fetches the data via http-Get; server computes the result dataset using the fetched data and the requested function and parameters; server stores data in cache; server sends the result data as response of the http-Post request to the client; end. I wonder if Squid could help us to cache the data accosiated to the client http-Post request. My idea is to generate a unique key of the http-Post request to make it cacheable. Thanks so much for your response. Farkas On 8 September 2012 04:48, Amos Jeffries <squ...@treenet.co.nz> wrote: > On 7/09/2012 9:39 a.m., Farkas H wrote: >> >> Hi Amos, >> >> thanks for your response. >> I modified the web application. Now we have the following infrastructure. >> client --> http-Post [embedded http-Get] --> Server / web application >> --> http-Get --> Squid -> Servers (-> Squid -> Server / web >> application -> client) >> Advantage: The Server / web application doesn't have to request data >> from the remote servers if it's in the Squid cache. >> >> Additionally I want to cache the http-Post requests. >> client --> http-Post --> Squid --> Server / web apllication / >> processing the response (-> Squid -> client) > > > Requests body is not cacheable in HTTP. > > The body content is the state to be changed at end-server resource in the > URL. Caching it is meaningless, since next time the state needs to be > changed you CANNOT simply reply from a middleware cache saying "server state > now changed" without passing any of those details to the server. > > Additionally, your translation service is re-writing the POST into GET > requests so the POST ceases to exist at your gateway service. There is > nothing to cache. > > > >> >> The idea: We modify the header of the http-post request to make it unique. >> The information whether Squid has a stored response to the modified >> request (true or false) should be added to the request / should be >> forwarded to the destination server. There are two possibilities. >> (1) The modified request is not stored in Squid (new request). >> (2) The modified request is stored in Squid. We don't know yet if the >> data is still fresh. >> The request should be forwarded in both(!) possibilities, (1) and (2), >> to the destination server. >> Is that possible with Squid? > > > Of course. That is dependent on the Cache-Control: headers the server > supplies to Squid with its responses and applies to each response > independent of anythign else. > > Send "Cache-Control: must-revalidate" and Squid will query the server for > each request asking if there are updates. > > Amos