-
Notifications
You must be signed in to change notification settings - Fork 102
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement server-side response cache #60
Comments
eZ Component's Cache library might be worth a look at. features: |
I would go for something much more simple, similar to what I proposed on #40.
Would probably use something like a new ProxyableOutput interface, similar to ProxyableThrough but for the entire output, not only the callback returns. Two closures are not that complex, yay? Also not sure about the closure params. Seems that these ones are enough. |
@alganet On both of these I am not entirely clear, would you elaborate please, don't forget the link? |
@nickl- can't remember why I mentioned streams! |
@alganet You had a skeleton interface for stream wrappers committed somewhere, I looked and I can't find the logs or issue anywhere. You had the idea to do processing ie md5/ETAG/caching via the wrappers, which sounds awesome but I only started thinking about it more at a later stage and I'm not entirely sure I didn't miss something else which is why I want to pick your brain on this again. Ring any bells now? |
Maybe I was wondering about auto-generated ETags for stream resources. I really can't remember, maybe I need to drink less =( |
Or it's time for another drink XD |
This is a topic I've been burning to raise but there are still features required that takes a higher priority than this. Since the RESTful API architecture involves extensive CACHE considerations there is not much need to further motivate the benefit of having a properly implemented CACHE solution at the end-point, aside from the obvious performance and load shedding advantages, to be able to verify and test conformance of the developed REST implementation without the need for external CACHE providersp
It is only until now that we are discussing conditional requests that this has become pertinent as the framework will see a huge benefit if it is able to cache and make request provisioning decisions based on cached variants rather than re-requesting the Routers to populate a response on every request. for state information.
2616 allows for ETag to be used as an "opaque" identifier instead of dates:
Although I this will not be sufficient as the only identifier and we will benefit from having an additionally indexed key when ETag is not available, based on a calculated checksum of the following HTTP artifacts:
(Of the top of my head this will have to be verified)
location
accept header
method
In the interim it is safe to speculate that we would consider plug-able cache provisioning utilizing some/all of the following :
via file cache - simple and free from dependencies utilizing PHPs file_put/file_get_contents();
via PDO as database driven cache
via APC provisioned
via REDIS provisioned
via Memcache provisioned
via APC provisioned
via Solr provisioned
via ElasticSearch provisioned
via Reverse Proxy (Squid probably) provisioned (not sure if this is exactly what we have in mind though.
Aside from the obvious requirement that the design should be flexible to easily cater for additions to this list of providers I would additionally see the functionality being transparently exposing an API that can be utilized by other components of the application where this functionality may be required without impacting the core cache.
What are your thoughts?
The text was updated successfully, but these errors were encountered: