Custom Query (2152 matches)
Results (112 - 114 of 2152)
Ticket
|
Resolution
|
Summary
|
Owner
|
Reporter
|
#537 |
duplicate
|
Caching and Performance improvement
|
wwaites
|
wwaites
|
Reported by wwaites,
4 years ago.
|
Description |
There are several places where performance is unacceptably slow. Even in places where it is not, the system could still be more responsive for read requests.
Introducing caching has to be done carefully and should be done in a standards compliant manner.
General strategy
- Where possible, cache output within the pylons app (beaker).
- Facilitate external caching in an end-user's web browser or a caching proxy
- Slightly stale data is not necessarily much of a problem so allow the output to be cached for a relatively short period (e.g. 5-15 minutes).
- When cache expiry has been reached, a request will be made to the server. The server should check if its internally cached data is still valid, and serve that, otherwise regenerate the data.
Tasks
These tasks should be broken into sub-tickets:
- caching of parts of templates that are expensive to render (package list, tag list, group list)
- caching of entire output using beaker particularly for API read operations.
- need to perform a check to see if the cache should be invalidated by checking if anything in the output would have changed -- i.e. checking timestamps on package modifications. this is a natural place to introduce the ETag which will help browsers and web caches.
- cache infrastructure front end - varnish, squid, etc. To do this right, the controllers need to set the cache control headers appropriately (max-age, must-revalidate). This is a good resource: http://www.mnot.net/cache_docs/#CACHE-CONTROL
- Deploy varnish on a host dedicated to this purpose for research. This will be useful for other sites as well
- Do not configure varnish to ignore cache control headers or otherwise behave in a non HTTP/1.1 compliant manner
Future Work
- Investigate ckanclient library maintaining a local cache as a web browser would
- Investigate using a CDN like Google Storage or Amazon for serving cached data.
|
#543 |
duplicate
|
Investigate partial page caching and edge-side includes
|
wwaites
|
rgrp
|
Reported by rgrp,
4 years ago.
|
Description |
Edge-side includes or partial page caching are a standard way to deal with caching of pages in which some (usually small) part of the content cannot be cached or should be cached in a different manner (e.g. much more briefly) than the rest of the page.
Edge-side includes have the advantage that they integrate with general 3rd-party caching systems such as varnish.
Introducing either partial page or ESI will require some overhaul work to change the page render processing somewhat.
|
#544 |
duplicate
|
Backport facet browsing to CKAN 1.2
|
|
pudo
|
Reported by pudo,
4 years ago.
|
Description |
This is in IATI, would be nice to have in generic CKAN.
|
Note: See
TracQuery
for help on using queries.