Does a CacheLoader have to use a persistent store ?
No, a CacheLoader could for example fetch (and possibly store) its data from a webdav-capable webserver. Another example is a caching proxy server, which fetches contents from the web. Note that an implementation of CacheLoader may not implement the ‘store’ functionality in this case, but just the ‘load’ functionality.